数据库中注册用户表中有一个userid,和一个companyID就是会员ID 公司ID 现在我想公司ID从1000001开始编号,怎么样做比较合适 我不想第一条数据写死,然后设置成自动列 感觉那样太笨还有一个问题是有的地方看到数据库ID是CDS-121-232-DH23这种格式,注,这个格式不一定正确 大概这样,是变成的方式实现的 还是数据库实现的
解决方案 »
- 主表插入数据,从表如何根据主表的自增长ID同时插入数据?
- SQL有没遍历的方法,求一条SQL语句
- 关于 SQL Server2000 的查询问题
- sql2008 操作指南谁有?
- 有没有这样的软件或功能
- SQL中列名“x”无效问题:select a,b,x=a+b,y=0.8*x from t;
- 如何修改sqlserver默认创建数据库的路径
- 两个表联合查询(高难度)
- oracle 更新记录问题
- GODADDY国外空间的SQL2005数据库乱码
- sql server management studio无法连接到远端analysis services
- 不停的调用存储过程,在数据库中是生成一个存储过程还是调用就新生成一个?
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 行)
--*/
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
1 CREATE TABLE USER(ID int,cid int IDENTITY(10000000,1,INT)) 2用程序中的加密算法实现