• 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语句高。

  • 相关阅读:
    MFC生成的exe程序不能在其他电脑上运行怎么办
    MFC开发软件支持多语言且同时支持xp和win7操作系统
    MFC创建模态对话框与非模态对话框
    如何定位BAD_ACCESS
    iOS中几种数据持久化方案
    iOS NSString相关问题
    SPU
    WIKI
    Mac怎么快速创建便签和发送附件的邮件
    利用你的Mission Control--设置快速回到桌面等操作
  • 原文地址:https://www.cnblogs.com/niuben/p/11050478.html
Copyright © 2020-2023  润新知