SQLServer重置自增长列

 使用 SQL Server,新建表后想把测试数据删掉,让自增长列id重新开始算起。

方法1:使用 TRUNCATE TABLE 语句,基本语法如下所示:

TRUNCATE TABLE  table_name;

 TRUNCATE TABLE删除表中所有行,而不记录单个行删除操作,同时会清空表里面主键的标识,即重置自增长列。TRUNCATE TABLE速度快,使用的系统资源和事务日志资源更少,在功能上与没有WHERE的DELETE语句类似,但有些区别:

1、DROP删表,表结构将删了,当然数据也不存在了
2、TRUNCATE和DELETE删数据,表结构还在
3、DELETE可以带条件删除,TRUNCATE是全部删除
4、DELETE删除会写日志,TRUNCATE不写
5、DELETE效率低,数据可以恢复,TRUNCATE效率高,数据不可恢复

需要注意的是,当有外键约束时,无法truncate表,需要先禁用外键约束,如:

----禁用外键约束
ALTER TABLE TableName NOCHECK CONSTRAINT ALL;

----清空数据
TRUNCATE TABLE TableName

----启用外键约束
ALTER TABLE TableName CHECK CONSTRAINT ALL;

 补充:

 --查看约束状态(查询字典表 sys.foreign_keys,该字典表开始出现于sqlserver2005及以上版本):
select name , is_disabled from sys.foreign_keys order by name; 
 --其中:name  : 外键约束名称   is_disabled : 是否已禁用   0表示禁用   1表示未禁用

--删除外键
alter table AdItem drop constraint AdOrder_AdItem_FK1
 
--增加外键
alter table AdItem
add constraint AdOrder_AdItem_FK1 foreign key (AI_nOrderNo) references AdOrder(AO_nOrderNo)
 
--单个表的一个外键
alter table Student nocheck constraint FK__Student__SchoolN__4222D4EF 
alter table Student check constraint FK__Student__SchoolN__4222D4EF 
 
--单个表的所有外键
alter table Student nocheck constraint all 
alter table Student check constraint all 
 
--某个数据库的所有表
EXEC sp_MSforeachtable @command1='alter table ?  NOCHECK constraint all;
EXEC sp_MSforeachtable @command1='alter table ?  CHECK constraint all;

方法2:使用 DBCC CHECKIDENT 语句,基本语法如下所示:

 查询表的当前标识值:

dbcc checkident('tablename',noreseed)

重置表的当前标识值:

dbcc checkident('tablename',reseed,0)WITH NO_INFOMSGS

最后的那个 WITH  NO_INFOMSGS :取消显示所有信息性消息

  • 1
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值