MySQL中drop,delete和truncate的异同_MySQL, Oracle及数据库讨论区_Weblogic技术|Tuxedo技术|中间件技术|Oracle论坛|JAVA论坛|Linux/Unix技术|hadoop论坛_联动北方技术论坛  
网站首页 | 关于我们 | 服务中心 | 经验交流 | 公司荣誉 | 成功案例 | 合作伙伴 | 联系我们 |
联动北方-国内领先的云技术服务提供商
»  游客             当前位置:  论坛首页 »  自由讨论区 »  MySQL, Oracle及数据库讨论区 »
总帖数
1
每页帖数
101/1页1
返回列表
0
发起投票  发起投票 发新帖子
查看: 2246 | 回复: 0   主题: MySQL中drop,delete和truncate的异同        下一篇 
tngou
注册用户
等级:中校
经验:2433
发帖:192
精华:15
注册:2014-4-28
状态:离线
发送短消息息给tngou 加好友    发送短消息息给tngou 发消息
发表于: IP:您无权察看 2015-7-22 16:52:27 | [全部帖] [楼主帖] 楼主   主页

       相同点:

     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,除非使用reuse storage;truncate 会将高水线复位(回到最开始)。

     4.速度,一般来说: drop> truncate > delete

     5.安全性:小心使用 drop 和 truncate,尤其没有备份的时候.否则哭都来不及
        使用上,想删除部分数据行用 delete,注意带上where子句. 回滚段要足够大.
        想删除表,当然用 drop
        想保留表而将所有数据删除,如果和事务无关,用truncate即可。如果和事务有关,或者想触发trigger,还是用delete。
        如果是整理表内部的碎片,可以用truncate跟上reuse stroage,再重新导入/插入数据。




赞(0)    操作        顶端 
总帖数
1
每页帖数
101/1页1
返回列表
发新帖子
请输入验证码: 点击刷新验证码
您需要登录后才可以回帖 登录 | 注册
技术讨论