电脑蓝屏修复按哪个键开不了机

详解SQL中drop、delete和truncate的异同_mssql,sql server_ThinkSAAS
详解SQL中drop、delete和truncate的异同
详解SQL中drop、delete和truncate的异同
内容来源: 网络
第一:相同点:
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,除非使用truncate 会将高水线复位(回到最开始)。
4.速度:一般来说: drop& truncate & delete
5.安全性:小心使用 drop 和 truncate,尤其没有备份的时候.,否则哭都来不及。
6.使用上:想删除部分数据行用delete,注意带上where子句. 回滚段要足够大。
想删除表,当然用drop。
想保留表而将所有数据删除,如果和事务无关,用truncate即可;如果和事务有关,或者想触发trigger,还是用delete。
如果是整理表内部的碎片,可以用truncate跟上reuse stroage,再重新导入/插入数据。
文章很简短,不知道大家有没有对drop、delete和truncate的异同有所区分?
再为大家分享一些详细内容:
(1)DELETE语句执行删除的过程是每次从表中删除一行,并且同时将该行的删除操作作为事务记录在日志中保存以便进行进行回滚操作。TRUNCATE TABLE 则一次性地从表中删除所有的数据并不把单独的删除操作记录记入日志保存,删除行是不能恢复的。并且在删除的过程中不会激活与表有关的删除触发器。执行速度快。
(2)表和索引所占空间。当表被TRUNCATE 后,这个表和索引所占用的空间会恢复到初始大小,而DELETE操作不会减少表或索引所占用的空间。drop语句将表所占用的空间全释放掉。
(3)一般而言,drop & truncate & delete
(4)应用范围。TRUNCATE 只能对TABLE;DELETE可以是table和view
(5)TRUNCATE 和DELETE只删除数据,而DROP则删除整个表(结构和数据)。
(6)truncate与不带where的delete :只删除数据,而不删除表的结构(定义)drop语句将删除表的结构被依赖的约束(constrain),触发器(trigger)索引(index);依赖于该表的存储过程/函数将被保留,但其状态会变为:invalid。
(7)delete语句为DML(data maintain Language),这个操作会被放到rollback segment中,事务提交后才生效。如果有相应的 tigger,执行的时候将被触发。
(8)truncate、drop是DLL(data define language),操作立即生效,原数据不放到 rollback segment中,不能回滚
(9)在没有备份情况下,谨慎使用 drop 与 truncate。要删除部分数据行采用delete且注意结合where来约束影响范围。回滚段要足够大。要删除表用若想保留表而将表中数据删除,如果于事务无关,用truncate即可实现。如果和事务有关,或老师想触发trigger,还是用delete。
(10)Truncate table 表名 速度快,而且效率高,因为:
truncate table 在功能上与不带 WHERE 子句的 DELETE 语句相同:二者均删除表中的全部行。但 TRUNCATE TABLE 比 DELETE 速度快,且使用的系统和事务日志资源少。DELETE 语句每次删除一行,并在事务日志中为所删除的每行记录一项。TRUNCATE TABLE 通过释放存储表数据所用的数据页来删除数据,并且只在事务日志中记录页的释放。
(11)TRUNCATE TABLE 删除表中的所有行,但表结构及其列、约束、索引等保持不变。新行标识所用的计数值重置为该列的种子。如果想保留标识计数值,请改用 DELETE。如果要删除表定义及其数据,请使用 DROP TABLE 语句。
(12)对于由 FOREIGN KEY 约束引用的表,不能使用 TRUNCATE TABLE,而应使用不带WHERE子句的DELETE 语句。由于TRUNCATE TABLE不记录在日志中,所以它不能激活触发器。
以上就是本文的全部内容,希望对大家的学习有所帮助。
PHP开发框架
开发工具/编程工具
服务器环境
ThinkSAAS商业授权:
ThinkSAAS为用户提供有偿个性定制开发服务
ThinkSAAS将为商业授权用户提供二次开发指导和技术支持
让ThinkSAAS更好,把建议拿来。
开发客服微信博客访问: 356515
博文数量: 116
博客积分: 1968
博客等级: 上尉
技术积分: 1611
注册时间:
IT168企业级官微
微信号:IT168qiye
系统架构师大会
微信号:SACC2013
分类: Mysql/postgreSQL
sql中delete,drop ,truncate都代表删除,但3者又有一些区别&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,除非使用
truncate会将高水线复位(回到最开始).&
4.速度,一般来说: drop> truncate >;delete&&5.安全性:小心使用drop 和truncate,尤其没有备份的时候.否则哭都来不及&使用上,想删除部分数据行用delete,注意带上where子句. 回滚段要足够大.&想删除表,当然用drop ,想保留表而将所有数据删除.&如果和事务无关,用truncate即可.&如果和事务有关,或者想触发trigger,还是用delete.&如果是整理表内部的碎片,可以用truncate跟上reuse stroage,再重新导入/插入数据&&在实际应用中,三者的区别是明确的。&当你不再需要该表时, 用&&当你仍要保留该表,但要删除所有记录时, 用&
&当你要删除部分记录时(always with a WHERE clause), 用 delete.
阅读(1197) | 评论(0) | 转发(1) |
相关热门文章
给主人留下些什么吧!~~
请登录后评论。sql中truncate,delete,drop的区别-mysql教程-数据库-壹聚教程网sql中truncate,delete,drop的区别
这三个命令的相同点truncate和不带where子句的delete, 以及drop都会删除表内的数据,不同点是truncate会清除表数据表置id从1开始,delete就只删除记录,drop可以用来删除表或数据库并且将表所占用的空间全部释放
1. truncate和 delete只删除数据不删除表的结构(定义)
drop语句将删除表的结构被依赖的约束(constrain),(trigger),索引(index); 依赖于该表的存储过程/函数将保留,但是变为invalid状态.
Truncate是SQL中的一个删除数据表内容的语句,用法是:
  语法   TRUNCATE TABLE name   
&& 参数   name   
是要截断的表的名称或要删除其全部行的表的名称
Truncate table 表名 速度快,而且效率高,因为:   TRUNCATE TABLE 在功能上与不带 WHERE 子句的 DELETE 语句相同:二者均删除表中的全部行。但 TRUNCATE TABLE 比 DELETE 速度快,且使用的系统和事务日志资源少
2.delete语句是dml,这个操作会放到rollback segement中,事务提交之后才生效;如果有相应的trigger,执行的时候将被触发.
truncate,drop是ddl, 操作立即生效,原数据不放到rollback segment中,不能回滚. 操作不触发trigger.
DELETE 语句
DELETE 语句用于删除表中的行。
DELETE FROM 表名称 WHERE 列名称 = 值
&Fred Wilson& 会被删除:
DELETE FROM Person WHERE LastName = 'Wilson'
删除所有行
可以在不删除表的情况下删除所有的行。这意味着表的结构、属性和索引都是完整的:
DELETE FROM table_name或者:
DELETE * FROM table_name
3.delete语句不影响表所占用的extent
drop语句将表所占用的空间全部释放
truncate 语句缺省情况下见空间释放到 minextents个 extent,除非使用reuse storage.
4.速度,一般来说: drop& truncate & delete
有时候我们会决定我们需要从中清除一个表格。事实上,如果我们不能这样做的话,那将会是一个很大的问题,因为数据库管理师 (Database Administrator -- DBA) 势必无法对数据库做有效率的管理。还好,SQL 有提供一个 DROP TABLE的语法来让我们清除表格。 DROP TABLE 的语法是:
DROP TABLE &表格名&
我们如果要清除在SQL CREATE 中建立的顾客表格,我们就打入:
DROP TABLE customer.
5.安全性:小心使用drop 和truncate,尤其没有备份的时候.否则哭都来不及
使用上,想删除部分数据行用delete,注意带上where子句. 回滚段要足够大.
想删除表用drop
想保留表而将所有数据删除. 如果和事务无关,用truncate即可. 如果和事务有关,或者想触发trigger,还是用delete.
如果是整理表内部的碎片,可以用truncate跟上reuse stroage,再重新导入/插入数据。
总结,在使用上面三种命令时最好用delete来代替,其它两个都是非常危险工作,一不小心你的数据库或表可能被删除或清除哦。
上一页: &&&&&下一页:相关内容数据库(29)
转载来自:
中删除语句Drop、Delete、Truncate的相同点和不同点的比较(举例说明)
数据库删除语句的分别介绍:
Delete:用于删除表中的行(注:可以删除某一行;也可以在不删除表的情况下(即意味着表的结构、属性、索引完整)删除所有行)
& & & & & & & & 语法:删除某一行:Delete From 表名称 &Where 列名称=值
& & & & & & & 删除所有行: Delete From 表名称 & & & 或 & & Delete * &From &表名称
Drop:用于删除表(注:将表的结构、属性、索引也会被删除。)
& & & & & & & &语法:Drop &Table 表名称
Truncate:用于删除表内的数据(注:仅删除表内的数据,不删除表本身,相当于Delete语句不写Where子句一样)
语法:Truncate Table &表名称
数据库中删除语句的相同点和不同点的比较:
&1.truncate和不带where子句的delete,以及drop都能删除表内的数据
&2.truncate和delete只删除表数据保留表结构
不同点: & &
&1. truncate table tablename
& 删除表内容释放表空间保留表结构(即:只删除表内的数据,不删除表本身。相当于Delete语句不写where子句一样),不使用事务处理即和事务无关
& truncate 语句缺省情况下将空间释放到 minextents个 extent,
& 除非使用reuse storage;truncate 会将高水线复位(回到最开始)。
&2. delete table tablename [where子句]
& delete属于数据操作语言(DML),不能自动提交事务,需commit提交
& 这个操作会放到 rollback segement 中,事务提交之后才生效;
& 如果有相应的 trigger,执行的时候将被触发。
& delete 语句不影响表所占用的 extent,高水线(high watermark)保持原位置不动
&3. drop table tablename&
& drop属于数据定义语言(DDL)可以自动提交事务;
& drop 语句将删除表的结构被依赖的约束(constrain)、触发器(trigger)、索引(index)【删除表数据同时删除表结构】;
& 依赖于该表的存储过程/函数将保留,但是变为 invalid 状态。
& drop 语句将表所占用的空间全部释放。
&删除数据的速度,一般来说: drop& truncate & delete
使用场合:
& 当你不再需要该表时, 用
& 当你仍要保留该表,但要删除所有记录时, 用
& 当你要删除部分记录时(always with a where clause), 用 delete.
& 对于有主外键关系的表,不能使用truncate而应该使用不带where子句的delete语句,由于truncate不记录在日志中,不能够激活触发器
作者 韩学敏
参考知识库
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
访问:162283次
积分:3079
积分:3079
排名:第9218名
原创:99篇
转载:327篇
(1)(2)(2)(4)(5)(3)(6)(5)(3)(20)(22)(5)(2)(1)(1)(17)(13)(11)(53)(33)(23)(52)(86)(23)(16)(17)(1)

我要回帖

更多关于 电脑开机后屏幕没反应 的文章

 

随机推荐