• 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. 

  • 相关阅读:
    leetcode297
    leetcode4
    leetcode23
    leetcode72
    leetcode239
    leetcode42
    leetcode128
    leetcode998
    SAP MM GR-based IV, 无GR不能IV?
    小科普:机器学习中的粒子群优化算法!
  • 原文地址:https://www.cnblogs.com/sea-stream/p/13592643.html
Copyright © 2020-2023  润新知