> 数据库 > SQL Server 2008 >

SqlServer--delete、truncate 、Drop删除表的区别

--delete from 表名

--1>只是删除表中某些数据,表结构还在.。

--2>Delete 可以带where子句来删除一部分数据,例如 DELETE FROM Student WHERE sAge > 20

--3>自动编号不恢复到初始值。



--truncate table 表名

--1>truncate语句不能跟where条件,无法根据条件来删除,只能全部删除数据。

--2>自动编号恢复到初始值。

--3>使用truncate删除表中所有数据要比delete效率高的多,因为truncate操作采用按最小方式来记录日志.

--4>truncate删除数据,不触发delete触发器。



--drop table 表名

--1>删除表本身,即表中数据和表结构(列、约束、视图、键)全部删除。



自动编号解释:

1自动编号只会向前增长,不会倒退。
2如果插入数据出错,自动编号也会增长,下次插入时,编号会“跳过”。
3自动编号列是不能人为修改的。(一般情况)

(责任编辑:IT)