社区
MS-SQL Server
帖子详情
如何重置identity值?
sbks
2005-12-08 08:10:53
字段rowno int identity(1,1),在delete完数据之后,如何让rowno再次从1开始自动增长?
...全文
1228
5
打赏
收藏
如何重置identity值?
字段rowno int identity(1,1),在delete完数据之后,如何让rowno再次从1开始自动增长?
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用AI写文章
5 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
lw1a2
2005-12-08
打赏
举报
回复
见帮助里的dbcc checkident
samfeng_2003
2005-12-08
打赏
举报
回复
或者!:) 例
下例强制 jobs 表中的当前标识值为 30。
USE pubs
GO
DBCC CHECKIDENT (jobs, RESEED, 30)
GO
点点星灯
2005-12-08
打赏
举报
回复
truncate,delete,drop的异同点
说明:本文摘自oracle技术用户讨论组
truncate,delete,drop的异同点
注意:这里说的delete是指不带where子句的delete语句
相同点:truncate和不带where子句的delete, 以及drop都会删除表内的数据
不同点:
1. truncate和 delete只删除数据不删除表的结构(定义)
drop语句将删除表的结构被依赖的约束(constrain),触发器(trigger),索引(index); 依赖于该表的存储过程/函数将保留,但是变为invalid状态.
2.delete语句是dml,这个操作会放到rollback segement中,事务提交之后才生效;如果有相应的trigger,执行的时候将被触发.
truncate,drop是ddl, 操作立即生效,原数据不放到rollback segment中,不能回滚. 操作不触发trigger.
3.delete语句不影响表所占用的extent, 高水线(high watermark)保持原位置不动
显然drop语句将表所占用的空间全部释放
truncate 语句缺省情况下将空间释放到 minextents个 extent,除非使用reuse storage; truncate会将高水线复位(回到最开始).
4.速度,一般来说: drop> truncate > delete
5.安全性:小心使用drop 和truncate,尤其没有备份的时候.否则哭都来不及
使用上,想删除部分数据行用delete,注意带上where子句. 回滚段要足够大.
想删除表,当然用drop
想保留表而将所有数据删除. 如果和事务无关,用truncate即可. 如果和事务有关,或者想触发trigger,还是用delete.
如果是整理表内部的碎片,可以用truncate跟上reuse stroage,再重新导入/插入数据
点点星灯
2005-12-08
打赏
举报
回复
TRUNCATE TABLE
删除表中的所有行,而不记录单个行删除操作。
语法
TRUNCATE TABLE name
参数
name
是要截断的表的名称或要删除其全部行的表的名称。
注释
TRUNCATE TABLE 在功能上与不带 WHERE 子句的 DELETE 语句相同:二者均删除表中的全部行。但 TRUNCATE TABLE 比 DELETE 速度快,且使用的系统和事务日志资源少。
DELETE 语句每次删除一行,并在事务日志中为所删除的每行记录一项。TRUNCATE TABLE 通过释放存储表数据所用的数据页来删除数据,并且只在事务日志中记录页的释放。
TRUNCATE TABLE 删除表中的所有行,但表结构及其列、约束、索引等保持不变。新行标识所用的计数值重置为该列的种子。如果想保留标识计数值,请改用 DELETE。如果要删除表定义及其数据,请使用 DROP TABLE 语句。
对于由 FOREIGN KEY 约束引用的表,不能使用 TRUNCATE TABLE,而应使用不带 WHERE 子句的 DELETE 语句。由于 TRUNCATE TABLE 不记录在日志中,所以它不能激活触发器。
TRUNCATE TABLE 不能用于参与了索引视图的表。
示例
下例删除 authors 表中的所有数据。
TRUNCATE TABLE authors
点点星灯
2005-12-08
打赏
举报
回复
TRUNCATE TABLE name
SQL Server
重置
Identity
标识列的
值
(INT爆了)
一、背景 SQL Server数据库中表A中Id字段的定义是:[Id] [int]
IDENTITY
(1,1),随着数据的不断增长,Id
值
已经接近2147483647(int的取
值
范围为:-2 147 483 648 到 2 147 483 647)了,虽然已经对旧数据进行归档,但是这个表需要保留最近的1亿数据,有什么方法解决Id
值
就快爆的问题呢? 解决上面的问题有两个办法:一个是修改
如何
重置
identity
值
/* from: http://topic.csdn.net/t/20051208/20/4447231.html */ 字段rowno int
identity
(1,1),在delete完数据之后,如何让rowno再次从1开始自动增长? TRUNCATE TABLE name ************************* 下例强制 jobs
MySQL标识符identify_SQL Server
重置
Identity
标识列的
值
(INT爆了)
一、背景SQL Server数据库中表A中Id字段的定义是:[Id] [int]
IDENTITY
(1,1),随着数据的不断增长,Id
值
已经接近2147483647(int的取
值
范围为:-2 147 483 648 到 2 147 483 647)了,虽然已经对旧数据进行归档,但是这个表需要保留最近的1亿数据,有什么方法解决Id
值
就快爆的问题呢?解决上面的问题有两个办法:一个是修改表结构,把Id的...
SQL Server
重置
Identity
标识列的
值
(INT爆了(转)
一、背景 SQL Server数据库中表A中Id字段的定义是:[Id] [int]
IDENTITY
(1,1),随着数据的不断增长,Id
值
已经接近2147483647(int的取
值
范围为:-2 147 483 648 到 2 147 483 647)了,虽然已经对旧数据进行归档,但是这个表需要保留最近的1亿数据,有什么方法解决Id
值
就快爆的问题呢? 解决上面的问题有两个办法:一...
mysql
identity
重置
_Mysql中
Identity
详细介绍
假如表中包含一列为auto_increment,如果是Myisam类型的引擎,那么在删除了最新一笔数据,无论是否重启Mysql,下一次插入之后仍然会使用上次删除的最大ID+1. mysql> create table test_myisam (id int not null auto_increment primary key, name char(5)) engine=myisam;Que...
MS-SQL Server
34,597
社区成员
254,586
社区内容
发帖
与我相关
我的任务
MS-SQL Server
MS-SQL Server相关内容讨论专区
复制链接
扫一扫
分享
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章