一个mssql中关于一个数据类型为int的列,标识设成是1,标识种子为1,递增量设成1,但是在添加几个行时,又删除行时,列名不会自己减,是
rt,谢谢各位了。。 问题点数:20、回复次数:7Top
1 楼yjdn(人形机器)回复于 2005-06-02 22:47:12 得分 3
他本来就那样,你要是想让它变的话,自己做个触发器来实现吧Top
2 楼iamwei(David)回复于 2005-06-05 13:56:20 得分 0
请教楼上的,那触发器怎么做?Top
3 楼xiaonvjing(飞扬)回复于 2005-06-05 21:38:22 得分 4
你可以具体说说,你想实现什么样的效果,然后再想怎么写代码Top
4 楼zaisheng09(故雁)回复于 2005-06-05 21:59:36 得分 2
就是假设删除第6行,那么其后面所有行那‘一个数据类型为int的列’的数值全部减一~~
Top
5 楼iamwei(David)回复于 2005-06-05 22:29:25 得分 0
对,就是想列的数值能随着我们的增加和删除而相应的加减。不知道怎么做触发器,谢谢各位达人了。Top
6 楼631799(杭州工人)回复于 2005-06-05 23:16:36 得分 0
不用理它。Top
7 楼631799(杭州工人)回复于 2005-06-05 23:22:29 得分 11
--如果你要连续就这样:
create function f_newid()
returns char(7) --编号位数固定,用char的检索效率高于varchar
as
begin
declare @re char(7)
select @re=max(BHID) from 表
return(
case when @re is null then '1'
else @re+1
end)
end
go
--测试的表,表名与函数中的表名对应
create table 表(
BHID char(7) default dbo.f_newid() --设置默认值,自动生成编号
primary key, --设置成主键,防止编号冲突
-- constraint UNIQUE_BHID_表 unique, --如果用唯一约束,则删除上面的主键约束语句,改用此句
txt1 varchar(10),
txt2 varchar(10),
num float)
go
/*--插入数据时,就可以不理会编号字段,直接用这样的语句
多用户同时插入时,如果编号重复,就会有错误发生
此时,前台程序拦截错误,如果是违反约束的错误
只需要重新执行插入的语句即可,此时的编号会自动再重新生成
而重新执行插入语句也很方便,因为根本就不需要改语句
--*/
insert 表(txt1,txt2,num) values('aa','bb',1)
go
--删除测试
drop table 表
drop function f_newidTop




