drop table

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

例如删除 user 表:

drop table user;

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

例如删除 user 表:

truncate table user;

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

例如删除user表的所有数据

delete from 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。

更多相关文章

  1. Android异步加载图像小结 (含线程池,缓存方法)
  2. 【安卓笔记】android客户端与服务端交互的三种方式
  3. android WebView 图片缩放功能小结
  4. Android(安卓)Camera 使用小结
  5. android fragment学习5--fragment扩展 TabLayout非自定义
  6. Android(安卓)电源系列小结s
  7. Android三种实现定时器的方法
  8. android 沉浸式状态栏的三种方法
  9. Android中自定义对话框小结

随机推荐

  1. Nginx如何支持HTTPS?手把手教贼简单!
  2. 40K+Star!Mall电商实战项目开源回忆录!
  3. mall-swarm微服务电商系统如何部署?用Jenk
  4. Github标星 8K+,免费又好用的Redis客户端
  5. 简单的路径规划案例分享
  6. 还在手写任务调度代码?试试这款可视化分布
  7. 还在百度Docker命令?推荐一套我用起来特顺
  8. SharePoint 解决方案:如何获取所有List Te
  9. 还在手动整合Swagger?Swagger官方Starter
  10. Swagger界面丑、功能弱怎么破?用Postman增