数据库中注册用户表中有一个userid,和一个companyID就是会员ID 公司ID 现在我想公司ID从1000001开始编号,怎么样做比较合适 我不想第一条数据写死,然后设置成自动列 感觉那样太笨还有一个问题是有的地方看到数据库ID是CDS-121-232-DH23这种格式,注,这个格式不一定正确 大概这样,是变成的方式实现的 还是数据库实现的

解决方案 »

  1.   

    1.create table user(Id int,cid int identity(1000000,1,int))
    2.程序或存储过程实现。
      

  2.   

    --根据输入类别自动生成编号示例--表
    create table tab(a varchar(20),b varchar(100))
    go--触发器
    create trigger tr_insert on tab
    instead of insert
    as
    declare @dt varchar(10)
    set @dt='-'+convert(varchar(10),getdate(),120)select * into #t 
    from inserted a join(
    select gid_new=b.a,sid_new=1000001+isnull(max(cast(right(a.a,5) as int)),0)
    from tab a 
    right join inserted b on charindex(b.a+@dt,a.a)=1
    group by b.a
    )b on a.a=b.gid_new
    order by b.gid_newdeclare @nid varchar(100),@a int
    update #t set @a=case @nid when gid_new then @a+1 else sid_new end
    ,a=gid_new+@dt+'-'+right(@a,5)
    ,@nid=gid_newinsert tab select a,b from #t
    go--插入数据
    insert tab values('sj','2222')
    insert tab  select 'sj','324324'
    union  all  select 'sj','33343'
    union  all  select 'dj','33343'
    union  all  select 'dj','24324'
    union  all  select 'sj','24234'--显示插入结果
    select * from tab order by a
    go--删除测试
    drop table tab/*--测试结果a                    b       
    -------------------- --------
    dj-2004-07-1-00001   33343
    dj-2004-07-1-00002   24324
    sj-2004-07-1-00001   2222
    sj-2004-07-1-00002   324324
    sj-2004-07-1-00003   33343
    sj-2004-07-1-00004   24234(所影响的行数为 6 行)
    --*/
      

  3.   

    小良的古董结果,我给洗洗dj-2008-05-1-00001 33343
    dj-2008-05-1-00002 24324
    sj-2008-05-1-00001 2222
    sj-2008-05-1-00002 324324
    sj-2008-05-1-00003 33343
    sj-2008-05-1-00004 24234
      

  4.   

      
     1 CREATE TABLE USER(ID int,cid int IDENTITY(10000000,1,INT)) 2用程序中的加密算法实现