• 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,再重新导入/插入数据

  • 相关阅读:
    使用VS进入源码调试
    Nlog配置
    一个极简的爬虫
    简单的调用图灵机器人
    docker部署netcore项目 nginx负载均衡
    windows nginx负载均衡
    windows服务器环境配置redis sentinel部署
    ASP.NET资源大全-知识分享
    ABP动态生成WebAPI
    windows服务器环境下安装redis
  • 原文地址:https://www.cnblogs.com/hulianweb/p/11526362.html
Copyright © 2020-2023  润新知