zl程序教程

您现在的位置是:首页 >  数据库

当前栏目

sql自增长设置与删除的深入分析

SQL 设置 删除 增长 深入分析
2023-06-13 09:15:00 时间
identity(1,1)是指每插入一条语句时这个字段的值增1,
语法
IDENTITY  [  (  seed  ,  increment  )  ]
参数
seed
装载到表中的第一个行所使用的值(标示种子)。
increment
增量值,该值被添加到前一个已装载的行的标识值上(标示增量)。
必须同时指定种子和增量,或者二者都不指定。如果二者都未指定,则取默认值  (1,1)。
例如:
createtableWorkRoom
(WorkRoomIDintnotnullidentity(1,1)primarykey,
WorkRoomNameVarchar(50)null,
TeacherNameVarchar(10)null,
WorkRoomManagerVarchar(10)null,
WorkRoomPlanVarchar(max)null,
PurlVarchar(50)null,
RemarksVarchar(max)null,
)
修改s创建标示和删除标示:
ALTERTABLETABLENAMEDROPCOLUMNID
ALTERTABLETABLENAMEADDIDintidentity(1,1)notnull
 
如何用sql语句去掉列的自增长(identity)
========================================
如何用sql语句去掉列的自增长(identity),取消标识命令:
**无法通过alter把现有自增字段改为非自增
比如altertableaalteridint,自增属性不会去掉
通过修改系统表可以做到(此法可能有不可预知的结果,慎之...)
sp_configure"allowupdates",1
GO
reconfigurewithoverride
GO
updatesyscolumnssetcolstat=colstat&0x0000
whereid=object_id("表名")andname="字段名"
GO
sp_configure"allowupdates",0
---------------------------------
--折中的办法
altertableaaddxxxint
updateasetxxx=id
altertableadropcolumnid
execsp_rename"xxx","id","column"
========================================
第一个方法是可以去掉,但以后可能会导致出问题,建议用第二个方法,我用的语句现在也贴出来,也许需要的朋友有些用处
删除表zx_user中字段userid的自增长属性方法:
//新建临时字段
altertablezx_useradduseridtmpintnull
//赋值
updatezx_usersetuseridtmp=userid
//删除主键
altertablezx_userdroppk_zx_user
//删除字段
altertablezx_userdropcolumnuserid
//增加字段
altertablezx_useradduseridintnull
//把值还原回来
updatezx_usersetuserid=useridtmp
//删除临时字段
altertablezx_userdropcolumnuseridtmp
//修改新建字段不为空
altertablezx_useraltercolumnuseridintnotnull
//健主键,多个字段做主键,用逗号隔开,比如primarykey(userid,xxxxxx)
altertablezx_useraddprimarykey(userid)
========================================
删除主键时候,不知道你主键名字,请用一下方法查询:
select*fromsysobjectswherextype="PK