900字范文,内容丰富有趣,生活中的好帮手!
900字范文 > Sql Server实现自动增长

Sql Server实现自动增长

时间:2019-01-17 01:28:20

相关推荐

Sql Server实现自动增长

在学习中遇到这个问题

数据库里有编号字段

BH00001

BH00002

BH00003

BH00004

如何实现自动增长

--下面的代码生成长度为8的编号,编号以BH开头,其余6位为流水号。--得到新编号的函数CREATE FUNCTION f_NextBH()RETURNS char(8)ASBEGINRETURN(SELECT 'BH'+RIGHT(1000001+ISNULL(RIGHT(MAX(BH),6),0),6) FROM tb WITH(XLOCK,PAGLOCK))ENDGO--在表中应用函数CREATE TABLE tb(BH char(8) PRIMARY KEY DEFAULT dbo.f_NextBH(),col int)--插入资料BEGIN TRANINSERT tb(col) VALUES(1)INSERT tb(col) VALUES(2)INSERT tb(col) VALUES(3)DELETE tb WHERE col=3INSERT tb(col) VALUES(4)INSERT tb(BH,col) VALUES(dbo.f_NextBH(),14)COMMIT TRAN--显示结果SELECT * FROM tb/*--结果BH col---------------- -----------BH000001 1BH000002 2BH000003 4BH000004 14--*/create table tb(id int identity,name varchar(10),code as 'BH'+right('0000'+cast(id as varchar),5))goinsert tb(name) select 'A'union all select 'B'union all select 'C'union all select 'D'select * from tbdrop table tb/*idname code ----------- ---------- ------------1 ABH000012 BBH000023 CBH000034 DBH00004

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。