MySQL删除表操作(delete、truncate、drop的区别) |
您所在的位置:网站首页 › delete与drop的区别 › MySQL删除表操作(delete、truncate、drop的区别) |
本文主要讲mysql中三种删除表的操作,delete语句、truncate语句以及drop语句的区别: 简介 delete1、删除整张表的数据: delete from table_name;2、删除部分数据,添加where子句: delete from table_name where...;3、说明 1)、属于DML语言,每次删除一行,都在事务日志中为所删除的每行记录一项。产生rollback,事务提交之后才生效;如果有相应的 trigger,执行的时候将被触发,如果删除大数据量的表速度会很慢。 2)、删除表中数据而不删除表的结构(定义),同时也不释放空间。 truncate1、只能操作表,将表中数据全部删除,在功能上和不带where子句的delete语句相同: truncate table table_name;2、说明 1)、默认情况下,truncate通过释放存储表数据所用的数据页来删除数据,并且只在事务日志中记录页的释放。所以使用的系统和事务日志资源少,可以使用reuse storage; truncate会将高水线复位(回到最开始). 2 )、 truncate是DDL语言, 操作立即生效,自动提交,原数据不放到rollback segment中,不能回滚. 操作不触发trigger. 3 )、删除内容、释放空间但不删除表的结构(定义)。 dro |
今日新闻 |
推荐新闻 |
CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3 |