文档章节

MySQL删除表数据:DELETE 与 TRUNCATE 的区别

robortly
 robortly
发布于 2015/05/05 10:39
字数 624
阅读 122
收藏 4

在MySQL中有两种方法可以删除数据,一种是DELETE语句,另一种是TRUNCATE TABLE语句。DELETE语句可以通过WHERE对要删除的记录进行选择。而使用TRUNCATE TABLE将删除表中的所有记录。因此,DELETE语句更灵活。

  如果要清空表中的所有记录,可以使用下面的两种方法:

  DELETE FROM  tb_mail
  TRUNCATE TABLE tb_mail

  其中第二条记录中的TABLE是可选的。

  如果要删除表中的部分记录,只能使用DELETE语句。

  DELETE FROM table1 WHERE ...;

  如果DELETE不加WHERE子句,那么它和TRUNCATE TABLE是一样的,但它们有一点不同,那就是DELETE可以返回被删除的记录数,而TRUNCATE TABLE返回的是0。

  如果一个表中有自增字段,使用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等于"Mike"的前6条记录。可以使用如下的DELETE语句:

  DELETE FROM users WHERE name = 'niubi' LIMIT 6;

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

  DELETE FROM users WHERE name = 'niubi' ORDER BY id DESC LIMIT 6;tb_mail

© 著作权归作者所有

共有 人打赏支持
robortly

robortly

粉丝 9
博文 83
码字总数 55590
作品 0
深圳
技术主管
私信 提问
加载中

评论(1)

betty小雅
betty小雅
老师:
您好!
我是源智天下有限公司的图书编辑,公司诚聘兼职作者,撰写开发方面的书籍,版权和署名都归作者所有,提升您的知名度和个人影响力,流程我们带你完成,你只要在一定的时间内完成一定的内容即可,感兴趣的话可以详谈:2917227785或者3174229616,期待与您的合作!
mysql中delete table和truncate table的区别

delete from 表名; truncate table 表名; 不带where参数的delete语句可以删除mysql表中所有内容,使用truncate table也可以清空mysql表中所有内容。 效率上truncate比delete快,但truncate删...

issac宝华
2016/03/14
52
0
Mysql清空表(truncate)与删除表中数据(delete)的区别

为某基于wordpress搭建的博客长久未除草,某天升级的时候发现已经被插入了几万条垃圾留言,如果一条条删除那可真是累人的活。遂考虑直接进入mysql直接清空表或者删除表中数据。 本文记录一下...

三奇
2018/01/18
0
0
MySQL学习笔记(一)

一、数据库简单介绍 1、 按照数据库的发展时间顺序,主要出现了以下类型数据库系统: 网状型数据库 层次型数据库 关系型数据库 面向对象数据库 上面4中数据库系统中,关系型数据库使用最为广...

ws199358
2016/09/08
11
0
Mysql中常用操作(密码破解、数据库备份、数据库导入、授权)

修改表的编码方式: 修改字段的编码方式: 更改表的引擎: 刷新权限: 授权: Mysql密码修改/破解 输入这个命令后,需要输入root的原密码,然后root的密码将改为mypasswd。 2.MySQL 忘记口令...

殘留回憶
2017/12/06
0
0
Mysql TRUNCATE 和 DELETE 清空表操作的区别

本质: TRUNCATE 是 DDL(数据定义语言), DELETE 是 DML(数据操作语言) 所以 truncate 操作是无法在事务中回滚的,但 delete 在事务上下文中在 commit 前是可以回滚 常见的 DDL 命令还有...

big_cat
2016/01/29
167
0

没有更多内容

加载失败,请刷新页面

加载更多

node调用dll

先安装python2.7 安装node-gyp cnpm install node-gyp -g 新建一个Electron-vue项目(案例用Electron-vue) vue init simulatedgreg/electron-vue my-project 在package.json中的scripts里添......

Chason-洪
20分钟前
0
0
Linux系统快速查找文件的技巧

Linux常用命令中,有些命令可以帮助我们查找二进制文件,帮助手册或源文件的位置,也有的命令可以帮助我们查找磁盘上的任意文件,今天我们就来看看这些命令如何使用。 which which命令会在P...

Linux就该这么学
22分钟前
0
0
dotConnect for Oracle入门指南(八):通过OracleCommand类使用存储过程

【下载dotConnect for Oracle最新版本】 dotConnect for Oracle(原名OraDirect.NET)建立在ADO.NET技术上,为基于Oracle数据库的应用程序提供完整的解决方案。它为设计应用程序结构带来了新的...

电池盒
22分钟前
0
0
JavaScript是如何工作的:深入类和继承内部原理 + Babel和TypeScript 之间转换

摘要: 深入JS系列15。 原文:深入类和继承内部原理 + Babel和TypeScript 之间转换 作者:前端小智 Fundebug经授权转载,版权归原作者所有。 这是专门探索 JavaScript 及其所构建的组件的系列...

Fundebug
32分钟前
1
0
js 引用传值问题踩坑

先自测一下,答案在最下边。 <html><head><script type="text/javascript" src="/jquery/jquery.js"></script><script type="text/javascript">$(document).ready(function(){$("button......

S三少S
44分钟前
12
1

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部