• drop,delete与truncate的区别


    drop直接删掉表,truncate删除表中数据,再插入时自增长id又从1开始,delete删除表中数据,可以加where字句。

    1.delete 语句执行删除的过程是每次从表中删除一行,并且同时将该行的删除操作作为事务记录在日志 中保存以便进行回滚操作。truncate table则一次性地从表中删除所有的数据并不把单独的删除操作记 录记入日志保存,删除行是不能恢复的。并且在删除的过程中不会激活与表有关的删除触发器,执行速 度快。

    2.表和索引所占空间。当表被truncate后,这个表和索引所占用的空间会恢复到初始大小,而delete操 作不会减少表或索引所占用的空间。drop语句将表所占用的空间全释放掉。

    3.一般而言,drop>truncate>delete

    4.应用范围。truncate只能对table,delete可以是table和view

    5.truncate和delete只删除数据,而drop则删除整个表(结构和数据) 

    6.truncate与不带where的delete:只删除数据,而不删除表的结构(定义)drop语句将删除表的结构被 依赖的约束(constrain),触发器(trigger)索引(index);依赖于该表的存储过程/函数将被保留,但其状态 会变为:invalid. 

  • 相关阅读:
    与 字符串 相关的操作 -- lua语言实现(带有浓厚的 lua 语法特性)
    03-BFC
    11-canvas
    JavaScript知识点 思维导图
    文件系统 函数
    Meta标签大全
    PHP 快速排序
    天气预报API开发
    Zend Studio XDebug调试配置
    启程
  • 原文地址:https://www.cnblogs.com/sea-stream/p/13592643.html
Copyright © 2020-2023  润新知