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

相关推荐

  • Java干货 | 一文搞懂ORACLE数据库

    什么是 ORACLE? ORACLE数据库系统是美国ORACLE公(甲骨文)提供的以分布式数据库为核心的一组软件产品,是目前最流行的客户/服务器(CLIENT/SERVER)或B/S体系结构的数据库之一。 ORACLE通常应用于大型系统的数据库产品…

    2023年5月13日
    04
  • 经验分享jdbc怎么连接mysql数据库。

    要使用JDBC连接MySQL数据库,您需要下载并安装MySQL的JDBC驱动程序。您可以使用Java代码和JDBC驱动类连接到MySQL数据库。以下是一些步骤:,,1. 下载MySQL JDBC驱动程序。,2. 将JDBC驱动程序添加到Java项目的类路…

    2024年7月14日
    00
  • 关于mongodb创建数据库。

    MongoDB是一个非常流行的NoSQL数据库,它以其高性能、高可用性和易扩展性而受到许多开发者的喜爱,在MongoDB中,我们可以使用`use`命令来创建一个新的数据库,本文将介绍如何在MongoDB中创建一个新的数据库,并提供…

    2024年6月20日
    00
  • 我来教你MySQL中的不等于条件详解。

    在MySQL中,不等于条件用于筛选出不符合指定条件的记录,它通常与SELECT、UPDATE和DELETE语句一起使用,以便对数据库中的数据进行操作,本节将详细介绍MySQL中的不等于条件,包括其语法、用法和示例。 (图片来源网…

    2024年6月20日
    00
  • 重蔚自留地php学习第三十九天——关于mysql事物触发器函数过程的总结

    数据备份 对数据表内容进行备份 备份:select [*/字段列表] into outfile 文件路径 [字段处理] [行处理] from 表 还原:load data infile 文件路径 into 表 [字段处理] [行处理] 备份 ---------------》 数据库 -&g…

    2018年10月26日
    0239
  • php操作mysql的具体的操作流程

    链接数据库 mysql_connect(‘服务器地址’,’用户名’,’密码’); 选择数据库并设置编码 选择数据库:mysql_select_db(‘数据库名’); 设置通信编码:mysql_ query(‘set names utf8’); 准备SQL语句 发生的语句分三大类:库…

    2018年3月23日 PHP自学教程
    0213
  • 服务器使用方法有哪些种类。

    服务器的使用方法和种类多种多样。常见的服务器类型包括物理服务器(独立服务器)、VPS服务器(虚拟专用服务器)、云服务器、虚拟主机以及裸金属服务器。根据应用场景的不同,我们还有数据库服务器用于运行和管理数…

    2024年7月9日
    01
  • 我来分享mysql存储过程不执行怎么解决。

    检查存储过程语法,确保参数和语句正确;使用调试工具定位问题;查看错误日志获取详细信息。 MySQL存储过程不执行的问题可能有多种原因,以下是一些常见的解决方法: 1、语法错误:检查存储过程中是否存在语法错误…

    2024年7月12日
    00

联系我们

QQ:951076433

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