含有自增序列的表中使用truncate与delete的不同结果

一个含有自增序列的表,使用delete跟truncate之后会有什么不同结果呢?

大概说一下,使用truncate,表中的记录全部被清除,如果向表中插入数据,那么数据的排序是从1开始的。

如果使用的是delete,那么记录的排序值不会被清除,它是一次累加上去的。下面给出一个小例子,可以参考一下

------------================================
--Author:oliver QIN
--DATE:2015-12-21
--DESC:INDETITY(1,1)使用delete跟truncate后排序是怎么变化的
---==========================================建表
if exists(select * from sysobjects where ID=OBJECT_ID(N‘TB‘) AND XTYPE=‘u‘)
drop table TB
CREATE TABLE TB(ID INT IDENTITY(1,1),NAME NVARCHAR(100),dtDate datetime)

INSERT INTO TB SELECT ‘JACK‘,SUBSTRING(convert(varchar,dateadd(dd,-day(getdate()),getdate()),120),1,10) UNION ALL
               SELECT ‘TOM‘ ,SUBSTRING(convert(varchar,dateadd(dd,-day(getdate()),getdate()),120),1,10)

--===============建立存储过程(delete),先判断是否存在数据,如果存在就删除,然后插入数据,看序列的变化
go
IF((SELECT COUNT(*) FROM SYSOBJECTS WHERE ID=OBJECT_ID(N‘P_sample_DELETE‘) AND XTYPE=‘P‘)>0 )
DROP PROC P_sample_DELETE
GO
CREATE PROC P_sample_DELETE
as
begin
   if((select count(*) from TB WHERE dtDate=SUBSTRING(convert(varchar,dateadd(dd,-day(getdate()),getdate()),120),1,10))>0)
  begin
    delete from TB --WHERE  dtDate=SUBSTRING(convert(varchar,dateadd(dd,-day(getdate()),getdate()),120),1,10)
  end
  INSERT INTO TB SELECT ‘JACK‘,SUBSTRING(convert(varchar,dateadd(dd,-day(getdate()),getdate()),120),1,10) UNION ALL
               SELECT ‘TOM‘ ,SUBSTRING(convert(varchar,dateadd(dd,-day(getdate()),getdate()),120),1,10)
end

GO
--===============建立存储过程(truncate),先判断是否存在数据,如果存在就删除,然后插入数据,看序列的变化

IF((SELECT COUNT(*) FROM SYSOBJECTS WHERE ID=OBJECT_ID(N‘P_sample_TRUNCATE‘) AND XTYPE=‘P‘)>0 )
DROP PROC P_sample_TRUNCATE
GO
CREATE PROC P_sample_TRUNCATE
as
begin
   if((select count(*) from TB WHERE dtDate=SUBSTRING(convert(varchar,dateadd(dd,-day(getdate()),getdate()),120),1,10))>0)
  begin
    TRUNCATE TABLE TB
  end
  INSERT INTO TB SELECT ‘JACK‘,SUBSTRING(convert(varchar,dateadd(dd,-day(getdate()),getdate()),120),1,10) UNION ALL
               SELECT ‘TOM‘ ,SUBSTRING(convert(varchar,dateadd(dd,-day(getdate()),getdate()),120),1,10)
end
--------------调用三次TRUNCATE
EXEC P_sample_TRUNCATE
EXEC P_sample_TRUNCATE
EXEC P_sample_TRUNCATE

输出结果如下:

-------------调用三次DELETE
EXEC P_sample_DELETE
EXEC P_sample_DELETE
EXEC P_sample_DELETE

输出结果如下:

时间: 2024-12-28 01:02:16

含有自增序列的表中使用truncate与delete的不同结果的相关文章

sql server 中删除表中数据truncate和delete的区别(转载自.net学习网)

我们都知道truncate table可以用来删除整个表的内容,它与delete后面不跟where条件的效果是一样.但除此之外,我们还清楚它们之间有其它的区别吗?本章我们将一起讨论truncate与delete区别. 我们先看一下truncate table的说明:删除表中的所有行,而不记录单个行删除操作.TRUNCATE TABLE在功能上与没有WHERE子句的DELETE语句相同:但是,TRUNCATE TABLE速度更快,使用的系统资源和事务日志资源更少. truncate table的语

Oracle中的Truncate和Delete语句

Oracle中的Truncate和Delete语句 首先讲一下,truncate命令: 语法:TRUNCATE  TABLE  table; 表格里的数据被清空,存储空间被释放. 运行后会自动提交,包括之前其它未提交的会话,因而一旦清空无法回退. 只有表格的创建者或者其他拥有删除任意表格权限的用户(如DBA)才能清空表格. TRUNCATE  TABLE  dept30; Table truncated. ---------------------------------------------

sql语句中---删除表结构drop,truncate和delete的异同点

参考别人总结,此内容仅供自己学习 一.sql中的语法 1.drop table 表名称                                      eg:drop table dbo.Sys_Test 2.truncate table 表名称                                eg:truncate table dbo.Sys_Test 3.delete from 表名称 where  列名称=值       eg:delete from dbo.Sys

Sql语句中的truncate,delete,drop的区别

相同点: 1.truncate和不带where子句的delete.以及drop都会删除表内的数据. 不同点: 1. truncate 和 delete 只删除数据不删除表的结构(定义) drop 语句将删除表的结构被依赖的约束(constrain).触发器(trigger).索引(index):依赖于该表的存储过程/函数将保留,但是变为 invalid 状态. 2. delete 语句是数据库操作语言(dml),这个操作会放到 rollback segement 中,事务提交之后才生效:如果有相

DML -- 数据操纵预言: insert/delete/update --多表连接修改/.多表连接删除/多表连接查询-- truncate 和 delete的区别

/* DML -- 数据操纵预言: insert/delete/update */ #一: 插入语句 /* 语法1: insert into 表名(列名,..,列名....) values(值1,值2,...),(值1,值2,...),(值1,值2,...); 语法2: insert into 表名 set 列名1=值1,列名2=值2,....; */ /*二: 修改语句 1.修改单表的记录 语法: update 表名 set 列1=新值1,列2=新值2,列2=新值2... where 筛选条件

SQL语句中----删除表数据drop、truncate和delete的用法

一.SQL中的语法 1.drop table 表名称                         eg: drop table  dbo.Sys_Test 2.truncate table 表名称                     eg: truncate  table dbo.Sys_Test   3.delete from 表名称 where 列名称 = 值      eg: delete from dbo.Sys_Test where test='test' 二.drop,tru

ssh关于含有外键的传值中无法识别正确的action的原因和解决办法

在含有外键的表中,要保存一个值到这个外键时:逻辑思路:需要先将jsp页面的值传到相应的action中,在这个action中需要引入这个外键的实体层和DAO层(DAO层只需set方法),在执行函数中对于外键的传值,应该先根据外键DAO层的方法来将这个外键传给外键的对象,然后将这个对象通过此表中的实体类中的方法保存到该表中. jsp: <div class="form-group has-warning"> <label class="control-label

Sql语句——删除表数据drop、truncate和delete的用法

一.SQL中的语法 1.drop table 表名称                         eg: drop table  dbo.Sys_Test   2.truncate table 表名称                     eg: truncate  table dbo.Sys_Test                     3.delete from 表名称 where 列名称 = 值      eg: delete from dbo.Sys_Test where te

修改表中数据

修改表中数据格式:update+表名+set+列名='表达式'+where 条件表达式update student set name='李四' where name ='43'删除表中数据格式:delete + from + 表名 +where 条件表达式说明:当选项缺省时,删除表中所有数据delete from student where csrq='1998-1-1'或者:格式:truncate +table +表名功能:删除表中所有数据删除表:drop table 删除表定义及该表的所有数