沃梦达 / IT编程 / 数据库 / 正文

关于SQL表中drop table和delete table的区别

删表是一个比较危险的操作,这次给了个机会就想尝试下,记得在mysql表中有两种操作,drop与delete,但是在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

IiBzcmM9

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

答案:

IiBzcmM9

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

IiBzcmM9

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

到此这篇关于sql表中drop table和delete table的区别的文章就介绍到这了,更多相关sql表drop table和delete table的区别内容请搜索编程学习网以前的文章希望大家以后多多支持编程学习网!

本文标题为:关于SQL表中drop table和delete table的区别