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字符串包含某个字符。

    Python字符串格式 在Python中,我们经常需要格式化字符串,以便在输出时插入变量值或执行其他操作,本文将介绍Python中的字符串格式化方法。 1、使用百分号(%)操作符 这是Python 2.x中最常用的字符串格式化方法,…

    2024年7月24日
    02
  • 我来教你lnmp是什么意思。

    【lnmp是什么意思】:LAMP、Nginx、MySQL和PHP的组合,其中L表示Linux操作系统,M表示MySQL数据库,N表示Nginx Web服务器,P表示PHP编程语言,lnmp是Linux、Nginx、MySQL和PHP的缩写,这个组合是一种常见的Web服务…

    2024年6月18日
    01
  • php数据库的表操作

    语句: Create table 表名( 字段名称1 字段属性(类型) 字段选项, 字段名称2 字段类型 字段选项, .......................... )表选项;   表选项:表字符集和数据引擎 字符集:charset=utf8; 数据引擎:默认i…

    2017年11月23日
    0291
  • 小编分享宝塔面板地址忘了。

    宝塔面板是一款非常实用的服务器管理工具,它可以帮助用户轻松地管理服务器、网站、数据库等,宝塔面板支持Linux系统,包括CentOS、Ubuntu、Debian等,同时也支持Windows系统,宝塔面板提供了丰富的功能,如网站管…

    2024年6月19日
    00
  • 我来说说aspnet做网站好吗。

    ASP.NET是一个免费的web框架,用于使用HTML、CSS和JavaScript构建强大的网站和web应用程序。它还可以创建WebApi并使用Web套接字等实时技术。 ASP.NET Core是ASP.NET的一种替代方法,也可以理解为ASP.NET的升级。 AS…

    2024年7月9日
    05
  • mysql_建立索引的优缺点

    建立索引的优缺点: 为什么要创建索引呢? 这是因为,创建索引可以大大提高系统的性能。  第一、通过创建唯一性索引,可以保证数据库表中每一行数据的唯一性。 第二、可以大大加快 数据的检索速度,这也是创建索引的…

    2017年10月19日
    0173
  • 小编分享为啥香港服务器适合做数据库服务器呢。

    香港服务器适合做数据库服务器的原因可以从多个角度进行分析,包括地理位置、网络环境、法律政策以及技术基础设施等。 地理位置优势 香港地处亚洲的中心位置,具有非常低的延迟连接到周边的亚洲国家及地区,对于面…

    2024年7月20日
    02
  • 小编分享虚拟主机测试方法有哪些类型。

    虚拟主机测试方法的类型有很多,包括CPU性能测试、文件IO性能测试、内存性能测试、网络带宽测试和数据库性能测试等。这些方法可以帮助您评估虚拟主机的性能和稳定性。 虚拟主机测试方法简介 虚拟主机是一种共享服务…

    2024年7月25日
    01

联系我们

QQ:951076433

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