A. sql server语句中delete和truncate的区别
相同点:
1.truncate和不带where子句的delete、以及drop都会删除表内的数据。
2.drop、truncate都是DDL语句(数据定义语言),执行后会自动提交。
不同点:
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,再重新导入/插入数据。
6.delete是DML语句,不会自动提交。drop/truncate都是DDL语句,执行后会自动提交。
7、TRUNCATE TABLE 在功能上与不带 WHERE 子句的 DELETE 语句相同:二者均删除表中的全部行。但 TRUNCATE TABLE 比 DELETE 速度快,且使用的系统和事务日志资源少。DELETE 语句每次删除一行,并在事务日志中为所删除的每行记录一项。TRUNCATE TABLE 通过释放存储表数据所用的数据页来删除数据,并且只在事务日志中记录页的释放。
8、TRUNCATE TABLE 删除表中的所有行,但表结构及其列、约束、索引等保持不变。新行标识所用的计数值重置为该列的种子。如果想保留标识计数值,请改用 DELETE。如果要删除表定义及其数据,请使用 DROP TABLE 语句。
9、对于由 FOREIGN KEY 约束引用的表,不能使用 TRUNCATE TABLE,而应使用不带 WHERE 子句的 DELETE 语句。由于 TRUNCATE TABLE 不记录在日志中,所以它不能激活触发器。
10、TRUNCATE TABLE 不能用于参与了索引视图的表。
资料来源于:
www.cnblogs.com/8765h/archive/2011/11/25/2374167.html
B. 关于SQL删除语句TRUNCATE和DELETE
简单说:TRUNCATE 删除数据表的结构 DELETE 删除数据表的数据 结构还在 如为字段设置了标识列 identity(1,1)TRUNCATE 删除数据后 再添加数据 就从1开始自增DELETE 删除数据后 再添加数据 原来的使用的就不能再用了 也就是不是从1开始了 因为原来的占用了
C. sql怎么删除一个表中的所有数据
删除表数据有两种方法:delete和truncate。具体语句如下:
一、RUNCATE TABLE name :
删除表中的所有行,而不记录单个行删除操作。在这个指令之下,表格中的资料会完全消失,可是表格本身会继续存在。
TRUNCATE TABLE 的语法:TRUNCATE TABLE name ,参数 name 是要截断的表的名称或要删除其全部行的表的名称。
二、Delete from tablename where 1=1
1、delete语法:
DELETE FROM 表名称 WHERE 列名称 = 值。
2、删除所有行:
可以在不删除表的情况下删除所有的行。这意味着表的结构、属性和索引都是完整的:DELETE FROM table_name。
(3)sqltruncate语句扩展阅读:
truncate和delete的共同点及区别:
1、 truncate和 delete只删除数据不删除表的结构(定义) 。
2、delete语句是dml,这个操作会放到rollback segement中,事务提交之后才生效;如果有相应的trigger,执行的时候将被触发。
truncate是ddl, 操作立即生效,原数据不放到rollback segment中,不能回滚. 操作不触发trigger。
3、delete语句不影响表所占用的extent, 高水线(high watermark)保持原位置不动 。truncate 语句缺省情况下见空间释放到 minextents个 extent,除非使用reuse storage; truncate会将高水线复位(回到最开始)。
4、速度,一般来说: truncate >delete 。
D. sql 删除语句
1、delete 语句用于删除表中的行。delete语句执行删除的过程是每次从表中删除一行,并且同时将该行的删除操作作为事务记录在日志中保存
语法:DELETE FROM 表名称 WHERE 列名称 = 值,
如:删除student表中姓名为张三丰的学生信息-delete from studentwhere name=‘张三丰’;
2、drop (删除表):删除内容和定义,释放空间。简单来说就是把整个表去掉.以后要新增数据是不可能的,除非新增一个表。
drop语句将删除表的结构被依赖的约束(constrain),触发器(trigger)索引(index);依赖于该表的存储过程/函数将被保留,但其状态会变为:invalid。
3、truncate (清空表中的数据):删除内容、释放空间但不删除定义(保留表的数据结构)。与drop不同的是,只是清空表数据而已。
注意:truncate 不能删除行数据,要删就要把表清空。
(4)sqltruncate语句扩展阅读:
数据库操作中,经常要用到删除表和删除表数据,在实际应用中,三者的区别是明确的。
当你不再需要该表时, 用 drop;
当你仍要保留该表,但要删除所有记录时, 用 truncate;
当你要删除部分记录时(always with a WHERE clause), 用 delete。
truncate 与delete 比较:
1、truncate table 在功能上与不带 WHERE 子句的 delete语句相同:二者均删除表中的全部行。
2、truncate 比 delete速度快,且使用的系统和事务日志资源少。
3、truncate 操作后的表比Delete操作后的表要快得多。
E. 关于SQL删除语句TRUNCATE和DELETE的问题
理解了本质你才会适时而用!
truncate你可以理解为ddl,
delete是dml。
ddl和dml的定义我不多说了。
truncate删数就跟直接格式化硬盘类似,不管有多少数据,我就直接删除,跟drop表一样,无非就是空表留下了。速度不用提,快的很!
delete删除是事务性的一条条删,要记录各种日志,以防你反悔回滚!
因此删一条,记录一条,慢死!
但是,并不是那个快就胡乱用,如果你平时总是需要整表删,那么你用哪个清楚了吧嘿嘿
delete往往用在事务性操作里面,比如删除一条多条数据,如果你用delete删除整表,实在浪费资源,而且对oracle来说,delete不会降低高水位,因此删的次数多了表操作会变慢!
这是讲删除整表时的操作,记住凡事都有两面性!truncate删除不可恢复!delete还可以恢复!
说了那么多,关键看怎么用,多多实践。我闲着没事干,打了这些字,算是理解这两个东西的基本入门概念,算是抛砖引玉!有分不用给我,因为我的这些概念到处都有。真正去用看自己了,那才是网络谷歌都没法查到的东西。
F. 用SQL语句删除某个表中的某行,truncate table 后面跟什么语句
truncate table是截断某个表,执行后那是一了百了,怎么可能只删一行。只删一行使用delete 表名 where 查询条件。
G. 关于SQL删除语句TRUNCATE和DELETE
TRUNCATE
是将你的表初始化。假如现在你的表中有10条数据,现在TRUNCATE
TABLE
的话,就会将表还原为你最初刚创建好时的状态。表刚创建好时肯定是没有任何数据。因此数据就都没有了。DELETE
TABLE虽然也将你表中的数据清除,但是在你的事务日志文件(LDF)里,还会有相应的记录。没有彻底删除。并且DELETE
TABLE
还可以删除指定列,比如我想删除ID为1的列。就可以写:
delete
表名
where
id=1
都是自己写的,希望对你有帮助!、、
H. 请问在sql中下列表中的内容清空用truncate table可以吗应该怎么写
truncate table慎用.
一般使用delete 语句删除表信息.
truncate table不光删除表信息,同时还将重置表的一些参数,比如 自增值.
delete tablename;
truncate table tablename ;
对于表中数据,效果是样的.都是删除.