MySQL删除表的三种方式(小结)
droptable
drop是直接删除表信息,速度最快,但是无法找回数据
例如删除user表:
droptableuser;
truncate(table)
truncate是删除表数据,不删除表的结构,速度排第二,但不能与where一起使用
例如删除user表:
truncatetableuser;
deletefrom
delete是删除表中的数据,不删除表结构,速度最慢,但可以与where连用,可以删除指定的行
例如删除user表的所有数据
deletefromuser;
删除user表的指定记录
deletefromuserwhereuser_id=1;
三种方式的区别
相同点
- truncate和不带where子句的delete,drop都会删除表内的数据;
- drop,truncate都是DDL语句(数据定义语言),执行后会自动提交;
不同点
- 语句类型:delete语句是数据库操作语言(DML),truncate,drop是数据库定义语言(DDL);
- 效率:一般来说drop>truncate>delete;
- 是否删除表结构:truncate和delete只删除数据不删除表结构,truncate删除后将重建索引(新插入数据后id从0开始记起),而delete不会删除索引(新插入的数据将在删除数据的索引后继续增加),drop语句将删除表的结构包括依赖的约束,触发器,索引等;
- 安全性:drop和truncate删除时不记录MySQL日志,不能回滚,delete删除会记录MySQL日志,可以回滚;
- 返回值:delete操作后返回删除的记录数,而truncate返回的是0或者-1(成功则返回0,失败返回-1);
小知识
delete与deletefrom区别
如果只针对一张表进行删除,则效果一样;如果需要联合其他表,则需要使用from
deletetb1fromtb1mwhereidin(selectidfromtb2);
用法总结
- 希望删除表结构时,用drop;
- 希望保留表结构,但要删除所有记录时,用truncate;
- 希望保留表结构,但要删除部分记录时,用delete。
到此这篇关于MySQL删除表的三种方式(小结)的文章就介绍到这了,更多相关MySQL删除表内容请搜索毛票票以前的文章或继续浏览下面的相关文章希望大家以后多多支持毛票票!