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自动编号列是不能人为修改的。(一般情况)

posted @ 2016-12-15 22:58  hao_1234_1234  阅读(47864)  评论(1编辑  收藏  举报