drop、delete、truncate的区别

drop直接删掉表;简单来说就是把整个表去掉.以后要新增数据是不可能的,除非新增一个表,

truncate删除的是表中的数据,再插入数据时自增长的数据id又重新从1开始;删除内容、释放空间但不删除定义。与drop不同的是,他只是清空表数据而已,他比较温柔.删除内容很容易理解,不删除定义也很容易理解,就是保留表的数据结构

delete删除表中数据, –虽然也是删除整个表的数据,但是过程是痛苦的(系统一行一行地删,效率较truncate低)…..可以在后面添加where字句。

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

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