详细了解SQL中delete,drop,truncate的区别和不同

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介: 详细了解SQL中delete,drop,truncate的区别和不同

 其实总体来说就一句话就可以概况了,当你不再需要该表时, 用 drop;当你仍要保留该表,但要删除所有记录时, 用 truncate;当你要删除部分记录时, 用 delete。


       看完这就好详细学习过SQL的家人就已经对他们有啥不同和使用场景已经有所概念了吧,但是往往在面试中与会遇到类似的这种问题,所以我们要其更加深入的了解。


命令格式:

1. delete from 表名 [where 条件]    --删除指定行
2.

TRUNCATE语句和DELETE语句的区别:

1.操作对象不同

1. delete:能删除表中或基于真实表创建的视图中的数据
2. truncate:只能删除表中的数据,无法应用在视图上

2.条件限制区别

1. delete:删除表中数据时,可以通过 where 关键字,进行选择性s删除
2. truncate:不能使用 where 关键字进行选择性删除

3.事务

1. delete:删除表中数据时,涉及到事务处理:回退(缓存)、提交、撤退
2. truncate:删除缓存时,不涉及缓存事务处理

4.删除效率

1. delete:由于 delete 删除数据时要考虑事务管理(缓存、回退机制、日志记录),所以当删除大批量数据时,速度慢,效率低,甚至达不到删除的目的
2. truncate:删除大批量数据时,速度快、效率高、但无法撤销

5.激活触发器

1. delete:在进行删除操作时,可能激活触发器的处理
2. truncate:不存在激活触发器处理

6.外键约束

1. delete:可以运用 SQL 语句、按照业务逻辑、按照一定的先后顺序可以删除相关表中的数据
2. truncate:不能删除对于由 foreign key 约束引用的表,不能删除该表中的数据

Truncate使用注意事项

TRUNCATE TABLE 在功能上与不带 WHERE 子句的 DELETE 语句相同:二者均删除表中的全部行。但 TRUNCATE TABLE 比 DELETE 速度快,且使用的系统和事务日志资源少。

DELETE 语句每次删除一行,并在事务日志中为所删除的每行记录一项。TRUNCATE TABLE 通过释放存储表数据所用的数据页来删除数据,并且只在事务日志中记录页的释放。

TRUNCATE TABLE 删除表中的所有行,但表结构及其列、约束、索引等保持不变。新行标识所用的计数值重置为该列的种子。如果想保留标识计数值,请改用 DELETE。如果要删除表定义及其数据,请使用 DROP TABLE 语句。

对于由 FOREIGN KEY 约束引用的表,不能使用 TRUNCATE TABLE,而应使用不带 WHERE 子句的 DELETE 语句。由于 TRUNCATE TABLE 不记录在日志中,所以它不能激活触发器。

TRUNCATE TABLE 不能用于参与了索引视图的表。

对用TRUNCATE TABLE删除数据的表上增加数据时,要使用UPDATE STATISTICS来维护索引信息。

如果有ROLLBACK语句,DELETE操作将被撤销,但TRUNCATE不会撤销。

总结:TRUNCATE语句和DELETE语句和drop语句的区别:

  • 1.delete语句,是DML语句,truncate语句通常被认为是DDL语句。
  • 2.delete语句,后面可以跟where子句,通常指定where子句中的条件表达式,只删3.除满足条件的部分记录,而truncate语句,只能用于删除表中的所有记录。
  • 3.truncate语句,删除表中的数据后,向表中添加记录时,自动增加字段的默认初始值重新从1开始,而使用delete语句,删除表中所有记录后,向表中添加记录时,自动增加字段的值,为删除时该字段的最大值加1,也就是在原来的基础上递增。
  • 4.delete语句,每删除一条记录,都会在日志中记录,而使用truncate语句,不会在日志中记录删除的内容,因此,truncate语句的执行效率比delete语句高。
  • 5.效率方面:drop > truncate > delete
  • 6.drop一般用于删除整体性数据 如表,模式,索引,视图,完整性限制等;delete用于删除局部性数据 如表中的某一元组
  • 7.DROP把表结构都删了;DELETE只是把数据清掉;truncate是将表进行清空
  • 8.当你不再需要该表时, 用 drop;当你仍要保留该表,但要删除所有记录时, 用 truncate;当你要删除部分记录时(always with a WHERE clause), 用 delete.

应用场景:

  1. 需要根据一定的业务条件删除数据时、且数据量、性能可控的情况下,可以考虑使用 delete from xxx where 业务条件
  2. 需要考虑事务提交、撤销的管理机制时,可以使用 delete
  3. 当需要删除大批量数据时,同时要求速度快,效率高并且w无需撤销时,可以使用 truncate
  4. 另外,在企业级开发中,实际上都是进行逻辑删除(将数据进行删除标识处理)、而并不进行物理上的删除
  5. 在实际生产环境中,一般情况下删除业务处理(过渡表)中的数据
  6. 在实际企业开发、维护过程中,不管使用 delete 还是 truncate 命令前,都要考虑数据的备份

相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
目录
相关文章
|
4月前
|
SQL XML Java
mybatis :sqlmapconfig.xml配置 ++++Mapper XML 文件(sql/insert/delete/update/select)(增删改查)用法
当然,这些仅是MyBatis功能的初步介绍。MyBatis还提供了高级特性,如动态SQL、类型处理器、插件等,可以进一步提供对数据库交互的强大支持和灵活性。希望上述内容对您理解MyBatis的基本操作有所帮助。在实际使用中,您可能还需要根据具体的业务要求调整和优化SQL语句和配置。
78 1
|
5月前
|
SQL 数据库
|
6月前
|
SQL 存储 NoSQL
. NoSQL和SQL的区别、使用场景与选型比较
【7月更文挑战第30天】. NoSQL和SQL的区别、使用场景与选型比较
92 15
|
5月前
|
SQL 安全 关系型数据库
关系型数据库SQL server DELETE 语句
【8月更文挑战第3天】
135 10
|
5月前
|
SQL 数据挖掘
|
5月前
|
SQL Java 数据库连接
|
6月前
|
SQL 索引
SQL DELETE 实例
【7月更文挑战第13天】SQL DELETE 实例。
58 6
|
4月前
|
关系型数据库 MySQL 网络安全
5-10Can't connect to MySQL server on 'sh-cynosl-grp-fcs50xoa.sql.tencentcdb.com' (110)")
5-10Can't connect to MySQL server on 'sh-cynosl-grp-fcs50xoa.sql.tencentcdb.com' (110)")
|
6月前
|
SQL 存储 监控
SQL Server的并行实施如何优化?
【7月更文挑战第23天】SQL Server的并行实施如何优化?
147 13
|
6月前
|
SQL
解锁 SQL Server 2022的时间序列数据功能
【7月更文挑战第14天】要解锁SQL Server 2022的时间序列数据功能,可使用`generate_series`函数生成整数序列,例如:`SELECT value FROM generate_series(1, 10)。此外,`date_bucket`函数能按指定间隔(如周)对日期时间值分组,这些工具结合窗口函数和其他时间日期函数,能高效处理和分析时间序列数据。更多信息请参考官方文档和技术资料。