sql表中drop table和delete table的区别

本文对比了在数据库操作中Delete与Drop的区别,Delete用于删除数据但保留表结构,支持回滚及条件过滤;Drop则完全移除表及其所有数据,不可逆。在MaxCompute等特定场景下,仅支持Drop操作。

问题:使用阿里云的maxcompute产品发现有中间表的产生,需要删除。

删表是一个比较危险的操作,这次给了个机会就想尝试下,记得在mysql表中有两种操作,drop与delete,但是在maxcompute产品中尝试时,该产品只支持drop操作。这里说下二者操作的区别。

stackoverflow上的解释:

https://stackoverflow.com/questions/1143915/what-is-the-difference-between-drop-table-and-delete-table-in-sql-server
提问

上述问题大意是在sql2008版本中,drop操作和delete操作二者会产生相同的结果吗?delete是一个粗暴的操作吗?

答案:
在这里插入图片描述

* drop操作会删除所有的数据以及表结构

* delete操作会删除数据,但会保留表结构,并且在之后需要时可以回滚数据。此外,delete操作还可以加一些其它的where条件,比如删除确定的记录。

在这里插入图片描述

总结:

* delete操作比drop操作稍微不彻底点,当错误删除后有挽回的余地。

SQL中,`DELETE` 语句 `DROP TABLE` 有以下多方面的区别: ### 功能用途 - `DELETE` 语句用于从中删除满足特定条件的行数据,它主要是对中的数据进行操作,而不会删除结构本身。例如,要删除 `employees` 中所有部门编号为 `10` 的员工记录,可以使用如下语句: ```sql DELETE FROM employees WHERE department_id = 10; ``` - `DROP TABLE` 用于完全删除整个,包括的结构、中的所有数据以及与该相关的索引、约束等。一旦执行,将不复存在。例如,要删除 `employees` ,可以使用如下语句: ```sql DROP TABLE employees; ``` ### 数据保留情况 - `DELETE` 操作只是移除中的部分或全部行,但结构依然存在,后续可以继续向该中插入新的数据。 - `DROP TABLE` 操作会将及其所有数据永久删除,无法再向该插入数据,除非重新创建该。 ### 资源释放 - `DELETE` 操作通常不会立即释放所占用的磁盘空间,不过它会标记这些被删除的行可以被后续插入的数据覆盖。 - `DROP TABLE` 操作会立即释放该所占用的所有磁盘空间。 ### 事务性 - `DELETE` 语句是事务性的,可以被回滚。如果在一个事务中执行了 `DELETE` 操作,在事务提交之前可以使用 `ROLLBACK` 语句撤销该操作。 ```sql START TRANSACTION; DELETE FROM employees WHERE department_id = 10; -- 如果需要撤销删除操作 ROLLBACK; ``` - `DROP TABLE` 语句通常不是事务性的(不同数据库系统可能有差异),一旦执行,无法通过回滚操作恢复被删除的。 ### 执行速度 - `DELETE` 语句的执行速度通常取决于的大小删除条件的复杂度。如果要删除大量数据,可能会比较耗时。 - `DROP TABLE` 语句的执行速度相对较快,因为它只是删除的定义相关元数据,不需要逐行处理数据。 ### 对依赖对象的影响 - `DELETE` 操作不会影响与相关的视图、存储过程、触发器等依赖对象,这些对象仍然可以正常使用。 - `DROP TABLE` 操作会导致所有依赖该的视图、存储过程、触发器等对象失效,因为它们所依赖的已经不存在。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

uncle_ll

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值