我的编程空间,编程开发者的网络收藏夹
学习永远不晚

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

短信预约 信息系统项目管理师 报名、考试、查分时间动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

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

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 删除表内容请搜索自学编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持自学编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

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

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

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

drop table drop 是直接删除表信息,速度最快,但是无法找回数据 例如删除 user 表:drop table user;truncate (table) truncate 是删除表数据,不删除表的结构,速度排第二,但不能与wh
2022-05-18

Redis批量删除Key的三种方式小结

目录一.使用命令行批量删除Redis的key二.使用图形界面工具RedisDesktopManager三.使用jedis批量删除keysRedis 中有删除单个 Key 的指令 del,但好像没有批量删除 Key 的指令,不过我们可以借助
2023-04-10

MySQL复制表的三种方式(小结)

复制表结构及其数据 下面这个语句会拷贝数据到新表中。 注意:这个语句其实只是把select语句的结果建一个表,所以新表不会有主键,索引。create table table_name_new as (select * from table_
2022-05-12

MySQL删除数据的三种方式

MySQL删除数据有以下三种方式:1. 使用DELETE语句:使用DELETE语句可以删除表中的一条或多条数据。语法如下:DELETE FROM 表名 WHERE 条件;其中,表名是要删除数据的表名,WHERE后面是删除的条件。例如,删除s
2023-09-22

Mysql三种常用的删除数据或者表的方式

本文介绍了MySQL删除数据的三种常用方式:DELETE语句:根据特定条件删除表中行。TRUNCATETABLE语句:快速删除表中所有行,比DELETE更快。DROPTABLE语句:删除表及其所有数据,注意不可撤销。选择删除方式取决于具体情况,DELETE用于根据条件删除特定行,TRUNCATETABLE用于快速删除所有行,DROPTABLE用于删除整个表。
Mysql三种常用的删除数据或者表的方式
2024-04-02

mysql中删除数据的四种方法小结

目录写在前面 方法介绍1. DELETE语句示例: 2. DROP TABLE语句:3. TRUNCATE TABLE示例:4. 使用外键约束:示例: 方法优缺点1. DELETE语句:2. TRUNCATE TABLE语句:3. DR
2023-10-11

redis加锁的三种方式小结

本文主要介绍了redis加锁的三种方式小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
2023-01-04

Oracle怎么删除数据,Oracle数据删除的三种方式

目录oracle怎么删除数据drop命令truncate命令delete命令关于truncate的小小总结最后Oracle怎么删除数据删除表(记录和结构)的语句delete——truncate—&mda
2023-02-15

mysql查看表结构的三种方法总结

目录mysql查看表结构1. show create table2. desc3. information_schema.COLUMNS获取所有的表结构及备注根据库名导出所有表信息根据库名导出所有表名及表备注mysql获取整个库的所有表,及
2022-07-06

Java中switch的三种用法方式小结

这篇文章主要介绍了Java中switch的三种用法方式小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
2023-05-16

Python列表删除的三种方法代码分享

1、使用del语句删除元素>>> i1 = ["a",'b','c','d']>>> del i1[0] >>> print(i1) ['b', 'c', 'd'] >>>del语句将值从列表中删除后,就再也无法访问它了。2、使用pop()
2022-06-04

编程热搜

目录