当我们必要清空一个表中的所有行时,除了利用 DELETE * FROM table 还可以利用 TRUNCATE TABLE 语句。
如果想要清空一个表, TRUNCATE TABLE 语句比 DELETE语句更加有用。
TRUNCATE TABLE 语法
TRUNCATE TABLE 的语法很简朴,如下:
- TRUNCATE [TABLE] table_name;
复制代码 此中 TABLE 关键字是可选的。也就是说, TRUNCATE t; 和 TRUNCATE TABLE t; 是等效的。
TRUNCATE TABLE 语句相当于先将此表删除,再创建一个新表。TRUNCATE TABLE 语句必要对操纵的表具有 DROP 权限。
TRUNCATE 与 DELETE 差别
虽然 TRUNCATE 与 DELETE 雷同,但是他们在以下几个方面存在差别:
- TRUNCATE 被归类为 DDL 语句,而 DELETE 被归类为 DML 语句。
- TRUNCATE 操纵无法被回滚,而 DELETE 可以被回滚。
- TRUNCATE 操纵删除和重建表,它的速度比 DELETE 快得多。
- TRUNCATE 操纵会重置表的自增值,而 DELETE 不会。
- TRUNCATE 操纵不会激活删除触发器,而 DELETE 会。
- TRUNCATE 操纵不返回代表删除行的数量的值,它通常返回 0 rows affected。DELETE 返回删除的行数。
- 如果一个表被其他表的外键引用,对此表的 TRUNCATE 操纵会失败。
TRUNCATE 实例
我们通过以下实例演示 TRUNCATE TABLE 的用法。
起首,我们利用下面的语句创建一个 test 表用于测试:
- CREATE TABLE test (
- id INT AUTO_INCREMENT PRIMARY KEY,
- v INT
- );
复制代码 然后我们利用下面的 sql 语句插入10 万条数据:
- Query OK, 100000 rows affected (1.24 sec)
- Records: 100000 Duplicates: 0 Warnings: 0
复制代码 通过以下 DELETE 语句删除所有表中的所有行:
- Query OK, 100000 rows affected (1.01 sec)
复制代码 补充:用下面的语句插入一行数据。
- INSERT INTO test (v) values (1);
复制代码 然后查看一下表中的数据:
- +--------+------+
- | id | v |
- +--------+------+
- | 131071 | 1 |
- +--------+------+
- 1 row in set (0.00 sec)
复制代码 这是 TRUNCATE TABLE 语句的返回结果。它告诉我们统共耗费 0.02 秒。这里可以看出 TRUNCATE 比 DELETE 快的多。
最后,我们用下面的语句插入一行数据:
- INSERT INTO test (v) values (1);
复制代码 然后查看一下表中的数据:
- +----+------+
- | id | v |
- +----+------+
- | 1 | 1 |
- +----+------+
- 1 row in set (0.00 sec)
复制代码 输出结果告诉我们,TRUNCATE 操纵后,自增列 id 的值重置为 1。这与 DELETE 操纵差别。
如果你必要在删除数据后仍旧保持原有的自增值,请不要利用 TRUNCATE。
结论
在本文中,我们介绍了在 MySQL 服务器上怎样利用 TRUNCATE TABLE 语句清空表。本文的要点如下:
- TRUNCATE TABLE 语句用于清空一个表。TABLE 关键字可以省略。
- TRUNCATE TABLE 相当于删除并重建表,它不能回滚。
- TRUNCATE TABLE 比 DELETE 速度快的多,尤其是对大数据表来说。
- TRUNCATE TABLE 会重置表的自增值。
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。 |