mysql中删除表记录delete from和truncate table的用法区别

昨天开发的时候遇到的问题,整理了一下,分享给大家,可以看看,有需要的话可以利用一下。

mysql中删除表记录delete from和truncate table的用法区别:

MySQL中有两种删除表中记录的方法,一种是delete from语句,另一种是truncate table语句。 
(1)delete from语句可以使用where对要删除的记录进行选择。而使用truncate table将删除表中的所有记录。因此,delete语句更灵活。
(2)如果要清空表中的所有记录,可以使用下面的两种方法:
delete from tablename
truncate table tablename
其中第二条记录中的table是可选的。
(3)如果要删除表中的部分记录,只能使用delete语句。
delete FROM table1 WHERE ;
如果delete不加WHERE子句,那么它和truncate table是一样的,但它们有一点不同,那就是delete可以返回被删除的记录数,而truncate table返回的是0。
(4)如果一个表中有自增字段,使用truncate table和没有WHERE子句的delete删除所有记录后,这个自增字段将起始值恢复成1.如果你不想这样做的话,可以在delete语句中加上永真的WHERE,如WHERE 1或WHERE true。
delete FROM table1 WHERE 1;
上面的语句在执行时将扫描每一条记录。但它并不比较,因为这个WHERE条件永远为true。这样做虽然可以保持自增的最大值,但由于它是扫描了所有的记录,因此,它的执行成本要比没有WHERE子句的delete大得多。

delete和truncate table的最大区别是delete可以通过WHERE语句选择要删除的记录。但执行得速度不快。而且还可以返回被删除的记录数。而truncate table无法删除指定的记录,而且不能返回被删除的记录。但它执行得非常快。

与标准的SQL语句不同,delete支持ORDER BY和LIMIT子句,通过这两个子句,我们可以更好地控制要删除的记录。如当我们只想删除WHERE子句过滤出来的记录的一部分,可以使用LIMIB,如果要删除后几条记录,可以通过ORDER BY和LIMIT配合使用。假设我们要删除users表中name等于”nike”的前6条记录。可以使用如下的delete语句:

delete FROM users WHERE name = 'nike' LIMIT 6;

一般MySQL并不确定删除的这6条记录是哪6条,为了更保险,我们可以使用ORDER BY对记录进行排序。

delete FROM users WHERE name = 'nike' ORDER BY id DESC LIMIT 6;

还有一点就是,如果要删除表中的所有数据,建议使用truncate table, 尤其是表中有大量的数据, 使用truncate table是将表结构重新建一次速度要比使用delete from快很多,而delete from是一行一行的删除,速度很慢.

本文来自投稿,不代表重蔚自留地立场,如若转载,请注明出处https://www.cwhello.com/6407.html

如有侵犯您的合法权益请发邮件951076433@qq.com联系删除

(0)
重蔚的头像重蔚管理团队
上一篇 2018年4月13日 09:49
下一篇 2018年4月17日 09:23

相关推荐

  • 我来教你MySQL中如何使用nvl函数。

    在MySQL中,使用IFNULL函数替代NVL函数。示例:SELECT IFNULL(column_name, value_if_null) FROM table_name;。 在MySQL中,NVL()函数用于将NULL值替换为另一个值,它的语法如下: NVL(expression, value_if_null) …

    2024年6月26日
    00
  • 我来说说ubuntu启动mysql。

    在Ubuntu系统中,启动MySQL数据库服务器非常简单,下面是详细的步骤: 1. 打开终端,你可以通过点击左上角的”应用”,然后在搜索框中输入”终端”,找到并点击它来打开终端。 2. 在终端中,输入…

    2024年6月16日
    00
  • 聊聊深入了解MySQL的三层索引树。

    MySQL是一种广泛使用的开源关系型数据库管理系统,它使用索引来提高查询性能,在MySQL中,索引可以分为三种类型:BTree索引、哈希索引和全文索引,BTree索引是最常用的索引类型,它使用三层索引树结构来存储数据,…

    2024年6月20日
    00
  • 我来说说免费mysql数据库空间怎么申请的。

    您可以从以下网站申请免费的MySQL数据库空间:SQLPub、db4free.net、wsfdb.cn、memfire。这些网站提供了不同数量和大小的存储空间,以及不同的限制和要求。请注意,这些服务可能不适用于生产环境,仅供测试和学习使…

    2024年7月9日
    00
  • 教你mysql删除数据库。

    MySQL删除数据库的命令是`DROP DATABASE`,其基本语法如下: DROP DATABASE database_name; `database_name`是你想要删除的数据库的名称,这个命令会立即删除指定的数据库,并且不会将其数据复制到其他地方,在执行…

    2024年6月20日
    00
  • 关于mysql数据库名称怎么变为大写字母。

    MySQL数据库名称无法直接变为大写字母,需要通过修改表名或字段名实现。 在MySQL数据库中,数据库名称的大小写是敏感的,默认情况下,数据库名称、表名和列名都是以小写字母存储的,有时我们可能需要将数据库名称变…

    2024年7月16日
    00
  • 今日分享查看mysql是否启动。

    MySQL是一种关系型数据库管理系统,广泛应用于各种场景,在本文中,我们将讨论如何查看MySQL是否启动,我们需要了解MySQL的启动过程,当MySQL服务器启动时,它会监听一个特定的端口(默认为3306),等待客户端的连接请…

    2024年6月20日
    00
  • 教你怎么重新配置mysql服务器。

    您可以使用以下方法重新配置MySQL服务器:使用SET语句修改配置项,也可以使用命令行工具实现配置项重载,还可以通过SIGHUP信号让MySQL重新读取配置文件。 MySQL服务简介 MySQL是一个关系型数据库管理系统,由瑞典My…

    2024年7月25日
    00

联系我们

QQ:951076433

在线咨询:点击这里给我发消息邮件:951076433@qq.com工作时间:周一至周五,9:30-18:30,节假日休息