zoukankan      html  css  js  c++  java
  • MySQL删除语句比较,清空表数据,重置自增长索引

    drop truncate delete 程度从强到弱

    1、drop table tb
    drop将表格直接删除,没有办法找回

    2、truncate (table) tb
    truncate 删除表中的所有数据,不能与where一起使用

    3、delete from tb (where)
    delete 删除表中的数据(可制定某一行)

    truncate和delete的区别

    ① 事务:truncate是不可以rollback的,但是delete是可以rollback的;
    原因:truncate删除整表数据(ddl语句,隐式提交),delete是一行一行的删除,可以rollback
    ② 效果:truncate删除后将重置索引(自增长id从零开始) ,delete不会删除索引
    ③ truncate 不能触发任何Delete触发器。
    ④ delete 删除可以返回行数

    TRUNCATE语句和DELETE语句的区别

    1、delete语句,是DML语句,truncate语句通常被认为是DDL语句。

    2、delete语句,后面可以跟where子句,通常指定where子句中的条件表达式,只删除满足条件的部分记录,而truncate语句,只能用于删除表中的所有记录。

    3、truncate语句,删除表中的数据后,向表中添加记录时,自动增加字段的默认初始值重新从1开始,而使用delete语句,删除表中所有记录后,向表中添加记录时,自动增加字段的值,为删除时该字段的最大值加1,也就是在原来的基础上递增。

    4、delete语句,每删除一条记录,都会在日志中记录,而使用truncate语句,不会在日志中记录删除的内容,因此,truncate语句的执行效率比delete语句高。

  • 相关阅读:
    自建mail服务器之一:dns解析
    区间树
    3d tech
    3d
    平板比较
    Node。js 访问gmail
    node nightmare 网页自动化测试 sample
    node start
    中國駐香港外交部
    create a simple COM object
  • 原文地址:https://www.cnblogs.com/niuben/p/11050478.html
Copyright © 2011-2022 走看看