主页 > 知识库 > MySQL删除表的三种方式(小结)

MySQL删除表的三种方式(小结)

热门标签:地方门户网站 网站排名优化 呼叫中心市场需求 服务外包 Linux服务器 AI电销 铁路电话系统 百度竞价排名

drop table

drop 是直接删除表信息,速度最快,但是无法找回数据

例如删除 user 表:

drop table user;

truncate (table)

truncate 是删除表数据,不删除表的结构,速度排第二,但不能与where一起使用

例如删除 user 表:

truncate table user;

delete from

delete 是删除表中的数据,不删除表结构,速度最慢,但可以与where连用,可以删除指定的行

例如删除user表的所有数据

delete from user;

删除user表的指定记录

delete from user where user_id = 1;

三种方式的区别

相同点

  • truncate和不带where子句的delete,drop都会删除表内的数据;
  • drop,truncate都是DDL语句(数据定义语言),执行后会自动提交;

不同点

  • 语句类型:delete语句是数据库操作语言(DML),truncate,drop是数据库定义语言(DDL);
  • 效率:一般来说 drop > truncate> delete;
  • 是否删除表结构:truncate和delete 只删除数据不删除表结构,truncate 删除后将重建索引(新插入数据后id从0开始记起),而 delete不会删除索引 (新插入的数据将在删除数据的索引后继续增加),drop语句将删除表的结构包括依赖的约束,触发器,索引等;
  • 安全性:drop和truncate删除时不记录MySQL日志,不能回滚,delete删除会记录MySQL日志,可以回滚;
  • 返回值:delete 操作后返回删除的记录数,而 truncate 返回的是0或者-1(成功则返回0,失败返回-1);

小知识

delete 与 delete from 区别

如果只针对一张表进行删除,则效果一样;如果需要联合其他表,则需要使用from

delete tb1 from tb1 m where id in (select id from tb2);

用法总结

  • 希望删除表结构时,用 drop;
  • 希望保留表结构,但要删除所有记录时, 用 truncate;
  • 希望保留表结构,但要删除部分记录时, 用 delete。

到此这篇关于MySQL删除表的三种方式(小结)的文章就介绍到这了,更多相关MySQL 删除表内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
  • mysql判断表是否存在然后批量删除的操作
  • MySQL删除数据,表文件大小依然没变的原因
  • MySQL 如何查找并删除重复记录的实现
  • MySQL 快速删除大量数据(千万级别)的几种实践方案详解
  • 删除mysql服务的具体方法
  • MySQL 处理重复数据的方法(防止、删除)
  • MySQL对数据库操作(创建、选择、删除)
  • Window下如何恢复被删除的Mysql8.0.17 Root账户及密码
  • Linux下彻底删除Mysql 8.0服务的方法
  • MySQL删除表操作实现(delete、truncate、drop的区别)
  • MySQL删除了记录不生效的原因排查

标签:崇左 黄山 兰州 湘潭 仙桃 湖南 铜川 衡水

巨人网络通讯声明:本文标题《MySQL删除表的三种方式(小结)》,本文关键词  ;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 收缩
    • 微信客服
    • 微信二维码
    • 电话咨询

    • 400-1100-266