百分百源码网-让建站变得如此简单! 登录 注册 签到领金币!

主页 | 如何升级VIP | TAG标签

当前位置: 主页>网站教程>数据库> mysql如何用下令删除数据?
分享文章到:

mysql如何用下令删除数据?

发布时间:10/01 来源:未知 浏览: 关键词:

在mysql中,可以使用“DELETE FROM <表名> [WHERE 子句] [ORDER BY 子句] [LIMIT 子句]”命令删除单个表中的数据;也可以使用“TRUNCATE [TABLE] 表名”删除数据表中的所有数据,清空表。

使用 DELETE 语句删除单个表中的数据

在 MySQL 中,可以使用 DELETE 语句来删除表的一行或者多行数据。

语法格局为:

DELETE FROM <表名> [WHERE 子句] [ORDER BY 子句] [LIMIT 子句]

语法说明如下:

  • <表名>:指定要删除数据的表名。

  • ORDER BY 子句:可选项。表示删除时,表中各行将依照子句中指定的次序停止删除。

  • WHERE 子句:可选项。表示为删除操纵限制删除前提,若省略该子句,则代表删除该表中的所有行。

  • LIMIT 子句:可选项。用于告知效劳器在操纵命令被返回到客户端前被删除行的最大值。

留意:在不使用 WHERE 前提的时候,将删除所有数据。

实例:删除表中的全部数据

删除 tb_courses_new 表中的全部数据,输入的 SQL 语句和施行结果如下所示。

mysql> DELETE FROM tb_courses_new;
Query OK, 3 rows affected (0.12 sec)
mysql> SELECT * FROM tb_courses_new;
Empty set (0.00 sec)

使用 TRUNCATE 语句删除数据表中的数据

TRUNCATE 关键字用于完全清空一个表。其语法格局如下:

TRUNCATE [TABLE] 表名

其中,TABLE 关键字可省略。

创建表 tb_student_course,插入数据并查询,SQL 语句和运转结果如下:

mysql> CREATE TABLE `tb_student_course` (
    -> `id` int(4) NOT NULL AUTO_INCREMENT,
    -> `name` varchar(25) NOT NULL,
    -> PRIMARY KEY (`id`)
    -> );
Query OK, 0 rows affected (0.04 sec)
mysql> INSERT INTO tb_student_course(name) VALUES ('Java'),('MySQL'),('Python');
Query OK, 3 rows affected (0.05 sec)
Records: 3  Duplicates: 0  Warnings: 0
mysql> SELECT * FROM tb_student_course;
+----+--------+
| id | name   |
+----+--------+
|  1 | Java   |
|  2 | MySQL  |
|  3 | Python |
+----+--------+
3 rows in set (0.00 sec)

使用 TRUNCATE 语句清空 tb_student_course 表中的记载,SQL 语句和运转结果如下:

mysql> TRUNCATE TABLE tb_student_course;
Query OK, 0 rows affected (0.04 sec)

mysql> SELECT * FROM tb_student_course;
Empty set (0.00 sec)

TRUNCATE 和 DELETE 的不同

从逻辑上说,TRUNCATE 语句与 DELETE 语句作用雷同,但是在某些状况下,两者在使用上有所不同。

  • DELETE 是 DML 类型的语句;TRUNCATE 是 DDL 类型的语句。它们都用来清空表中的数据。

  • DELETE 是逐行一条一条删除记载的;TRUNCATE 则是直接删除本来的表,再从新创立一个千篇一律的新表,而不是逐行删除表中的数据,施行数据比 DELETE 快。因此需要删除表中全部的数据行时,尽量使用 TRUNCATE 语句, 可以缩短施行时间。

  • DELETE 删除数据后,配合事件回滚可以寻回数据;TRUNCATE 不支撑事务的回滚,数据删除后没法寻回。

  • DELETE 删除数据后,系统不会从新设定自增字段的计数器;TRUNCATE 清空表记载后,系统会从新设定自增字段的计数器。

  • DELETE 的使用范畴更广,由于它可以通过 WHERE 子句指定前提来删除部分数据;而 TRUNCATE 不支撑 WHERE 子句,只能删除团体。

  • DELETE 会返回删除数据的行数,但是 TRUNCATE 只会返回 0,没有任何意义。

总结

当不需要该表时,用 DROP;当仍要保存该表,但要删除所有记载时,用 TRUNCATE;当要删除部分记载时,用 DELETE。

引荐教程:mysql视频教程

以上就是mysql如何用命令删除数据?的具体内容,更多请关注百分百源码网其它相关文章!

打赏

打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,你说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

百分百源码网 建议打赏1~10元,土豪随意,感谢您的阅读!

共有151人阅读,期待你的评论!发表评论
昵称: 网址: 验证码: 点击我更换图片
最新评论

本文标签

广告赞助

能出一分力是一分吧!

订阅获得更多模板

本文标签

广告赞助

订阅获得更多模板