zoukankan      html  css  js  c++  java
  • mysql中drop、delete、truncate的区别简述

    一、区别

    1.去什么?

    truncate table 和 delete只删除数据(记录)不删除表的结构;drop语句将删除表的数据(记录)和表结构依赖的约束(constrain),触发器(trigger),索引(index),保留依赖于该表的存储过程/函数,但是变为invalid状态 .

    譬如:delete 是单杀,truncate 是团灭,drop 是把电脑摔了。

     

    2.范畴:

    delete DML 语句,操作完以后如果没有不想提交事务还可以回滚,truncate drop DDL 语句,操作完马上生效,不能回滚.

    譬如:delete 是发微信说分手,后悔还可以撤回,truncate drop 是直接扇耳光说滚,不能反悔。

     

    3.在自增字段的表中:

    truncate之后的自增字段从1开始计数了[即truncate是摧毁原来的表重新创建一张结构相同的表(有原表的结构)],delete的仍保留原来的最数数值[即如果添加数据从最值+1开始],drop将表的结构也删除了(原表数据和结构都没有了)

     譬如:drop 是神舟火箭,truncate 是和谐号动车,delete 是自行车。

     

    二、总结:

    1.执行速度:一般,drop> truncate > delete。

    2.在使用drop和truncate时一定要注意,虽然可以恢复,但为了减少麻烦,还是要慎重。

    3.如果想删除部分数据用delete,注意带上where子句,回滚段要足够大;
    如果想删除表,当然用drop;
    如果想保留表而将所有数据删除,如果和事务无关,用truncate即可;
    如果和事务有关,或者想触发trigger,还是用delete
    如果是整理表内部的碎片,可以用truncate跟上reuse stroage,再重新导入/插入数据

  • 相关阅读:
    软件测试的重要性
    软件测试二三事
    白盒测试总结
    黑盒测试总结
    闰年测试以及非法输入的处理方法
    软件测试(3)-基于等价类划分的一个小例子
    第二周课堂小结以及习题思考
    软件测试人员的自身修养
    软件测试的目的和方法
    第七周学习笔记之灰盒测试
  • 原文地址:https://www.cnblogs.com/hulianweb/p/11526362.html
Copyright © 2011-2022 走看看