美文网首页
数据库的删除方法

数据库的删除方法

作者: Fly丶心晨 | 来源:发表于2020-11-10 09:57 被阅读0次

    数据库的删除方式分为三种

    一、drop

    命令格式:drop table  tb  ---tb表示数据表的名字,下同。

    说明:删除内容和定义,释放空间。简单来说就是把整个表去掉.以后要新增数据是不可能的,除非新增一个表。简单理解就是删干净了,没有遗留任何东西。

    二、truncate

    命令格式:truncate table  tb  ---tb表示数据表的名字,下同。

    说明:删除内容、释放空间但不删除定义,也就是数据表的结构还在。与drop不同的是,它只是清空表数据而已,它比较温柔。

    三、delete

    命令格式:delete table  tb  或 delete table  tb where 条件 ---tb表示数据表的名字,下同。

    说明:删除内容不删除定义,不释放空间。其中,delete table tb 虽然也是删除整个表的数据,但是过程是痛苦的(系统一行一行地删,效率较truncate低)。

    【关于truncate的总结】

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

    2、delete 语句每次删除一行,并在事务日志中为所删除的每行记录一项,所以可以对delete操作进行roll back。

    3、truncate 在各种表上无论是大的还是小的都非常快。如果有ROLLBACK命令Delete将被撤销,而 truncate 则不会被撤销。

    4、truncate 是一个DDL语言,向其他所有的DDL语言一样,它将被隐式提交,不能对 truncate 使用ROLLBACK命令。

    5、truncate 将重新设置高水平线和所有的索引。在对整个表和索引进行完全浏览时,经过 truncate 操作后的表比Delete操作后的表要快得多。

    6、truncate 不能触发任何Delete触发器。

    7、当表被清空后表和表的索引讲重新设置成初始大小,而delete则不能。

    8、不能清空父表。

    相关文章

      网友评论

          本文标题:数据库的删除方法

          本文链接:https://www.haomeiwen.com/subject/oavdbktx.html