Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >delete后加 limit是个好习惯么 ?

delete后加 limit是个好习惯么 ?

作者头像
java进阶架构师
发布于 2020-11-03 02:42:53
发布于 2020-11-03 02:42:53
51200
代码可运行
举报
文章被收录于专栏:Java进阶架构师Java进阶架构师
运行总次数:0
代码可运行

★★★建议星标我们★★★

公众号改版后文章乱序推荐,希望你可以点击上方“Java进阶架构师”,点击右上角,将我们设为星标”!这样才不会错过每日进阶架构文章呀。

2020年Java原创面试题库连载中

【000期】Java最全面试题库思维导图

【020期】JavaSE系列面试题汇总(共18篇)

【028期】JavaWeb系列面试题汇总(共10篇)

【042期】JavaEE系列面试题汇总(共13篇)

【049期】数据库系列面试题汇总(共6篇)

【053期】中间件系列面试题汇总(共3篇)

【065期】数据结构与算法面试题汇总(共11篇)

【076期】分布式面试题汇总(共10篇)

【077期】综合面试题系列(一)

【078期】综合面试题系列(二)

【079期】综合面试题系列(三)

【080期】综合面试题系列(四)

【081期】综合面试题系列(五)

【082期】综合面试题系列(六)

【083期】综合面试题系列(七)

【084期】综合面试题系列(八)

【085期】综合面试题系列(九)

【086期】综合面试题系列(十)

【087期】综合面试题系列(十一)

【088期】综合面试题系列(十二)

【089期】综合面试题系列(十三)

更多内容,点击上面蓝字查看

作者:_陈哈哈 https://blog.csdn.net/qq_39390545/article/details/107519747

在业务场景要求高的数据库中,对于单条删除和更新操作,在 delete 和 update 后面加 limit 1 绝对是个好习惯。比如,在删除执行中,第一条就命中了删除行,如果 SQL 中有 limit 1;这时就 return 了,否则还会执行完全表扫描才 return。效率不言而喻。

那么,在日常执行 delete 时,我们是否需要养成加 limit 的习惯呢?是不是一个好习惯呢?

在日常的 SQL 编写中,你写 delete 语句时是否用到过以下 SQL?

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
delete from t where sex = 1 limit 100; 

你或许没有用过,在一般场景下,我们对 delete 后是否需要加 limit 的问题很陌生,也不知有多大区别,今天带你来了解一下,记得 mark!

写在前面,如果是清空表数据建议直接用 truncate,效率上 truncate 远高于 delete,应为 truncate 不走事务,不会锁表,也不会生产大量日志写入日志文件;truncate table table_name 后立刻释放磁盘空间,并重置 auto_increment 的值。delete 删除不释放磁盘空间,但后续 insert 会覆盖在之前删除的数据上。详细了解请跳转另一篇博文《delete、truncate、drop 的区别有哪些,该如何选择》

下面只讨论 delete 场景,首先,delete 后面是支持 limit 关键字的,但仅支持单个参数,也就是 [limit row_count],用于告知服务器在控制命令被返回到客户端前被删除的行的最大值。

delete limit 语法如下,值得注意的是,order by 必须要和 limit 联用,否则就会被优化掉。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
delete \[low\_priority\] \[quick\] \[ignore\] from tbl\_name
  \[where ...\]
    \[order by ...\]
      \[limit row\_count\]

加 limit 的的优点:

以下面的这条 SQL 为例:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
delete from t where sex = 1; 

  • 1. 降低写错 SQL 的代价,就算删错了,比如 limit 500, 那也就丢了 500 条数据,并不致命,通过 binlog 也可以很快恢复数据。
  • 2. 避免了长事务,delete 执行时 MySQL 会将所有涉及的行加写锁和 Gap 锁(间隙锁),所有 DML 语句执行相关行会被锁住,如果删除数量大,会直接影响相关业务无法使用。
  • 3. delete 数据量大时,不加 limit 容易把 cpu 打满,导致越删越慢。

针对上述第二点,前提是 sex 上加了索引,大家都知道,加锁都是基于索引的,如果 sex 字段没索引,就会扫描到主键索引上,那么就算 sex = 1 的只有一条记录,也会锁表。


对于 delete limit 的使用,MySQL 大佬丁奇有一道题:

如果你要删除一个表里面的前 10000 行数据,有以下三种方法可以做到: 第一种,直接执行 delete from T limit 10000; 第二种,在一个连接中循环执行 20 次 delete from T limit 500; 第三种,在 20 个连接中同时执行 delete from T limit 500。

你先考虑一下,再看看几位老铁的回答:

--------------------------------------------

Tony Du:

  • 方案一,事务相对较长,则占用锁的时间较长,会导致其他客户端等待资源时间较长。
  • 方案二,串行化执行,将相对长的事务分成多次相对短的事务,则每次事务占用锁的时间相对较短,其他客户端在等待相应资源的时间也较短。这样的操作,同时也意味着将资源分片使用(每次执行使用不同片段的资源),可以提高并发性。
  • 方案三,人为自己制造锁竞争,加剧并发量。
  • 方案二相对比较好,具体还要结合实际业务场景。

-------------------------------------------- 肉山: 不考虑数据表的访问并发量,单纯从这个三个方案来对比的话。

  • 第一个方案,一次占用的锁时间较长,可能会导致其他客户端一直在等待资源。
  • 第二个方案,分成多次占用锁,串行执行,不占有锁的间隙其他客户端可以工作,类似于现在多任务操作系统的时间分片调度,大家分片使用资源,不直接影响使用。
  • 第三个方案,自己制造了锁竞争,加剧并发。

至于选哪一种方案要结合实际场景,综合考虑各个因素吧,比如表的大小,并发量,业务对此表的依赖程度等。 ------------------------------------------- ~嗡嗡:

  • 1. 直接 delete 10000 可能使得执行事务时间过长
  • 2. 效率慢点每次循环都是新的短事务,并且不会锁同一条记录,重复执行 DELETE 知道影响行为 0 即可
  • 3. 效率虽高,但容易锁住同一条记录,发生死锁的可能性比较高

-------------------------------------------

怎么删除表的前 10000 行。比较多的朋友都选择了第二种方式,即:在一个连接中循环执行 20 次 delete from T limit 500。确实是这样的,第二种方式是相对较好的。

第一种方式(即:直接执行 delete from T limit 10000)里面,单个语句占用时间长,锁的时间也比较长;而且大事务还会导致主从延迟。

第三种方式(即:在 20 个连接中同时执行 delete from T limit 500),会人为造成锁冲突。

这个例子对我们实践的指导意义就是,在删除数据的时候尽量加 limit。这样不仅可以控制删除数据的条数,让操作更安全,还可以减小加锁的范围。所以,在 delete 后加 limit 是个值得养成的好习惯。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
之前,给大家发过三份Java面试宝典,这次新增了一份,目前总共是四份面试宝典,相信在跳槽前一个月按照面试宝典准备准备,基本没大问题。《java面试宝典5.0(初中级)350道Java面试题:整理自100+公司》(中高级)《资深java面试宝典-视频版》(资深)《Java[BAT]面试必备》(资深)分别适用于初中级,中高级,资深级工程师的面试复习。内容包含java基础、javaweb、mysql性能优化、JVM、锁、百万并发、消息队列,高性能缓存、反射、Spring全家桶原理、微服务、Zookeeper、数据结构、限流熔断降级等等。获取方式:点“在看”,V信关注上述Java最全面试题库号并回复 【面试】即可领取,更多精彩陆续奉上。
看到这里,证明有所收获必须点个在看支持呀,喵
本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2020-10-18,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 java进阶架构师 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
delete 后加 limit 是个好习惯么?!
在业务场景要求高的数据库中,对于单条删除和更新操作,在删除和更新后加限制1绝对是个好习惯。这样,在删除执行中,第一条就命中了删除行,如果SQL中有限制1;这时就return了,否则将会执行完全表扫描才ret urn。效率不言而喻。
芋道源码
2020/10/27
1.1K0
delete 后加 limit 是个好习惯么?!
踩坑!JDK8中HashMap依然会死循环!
blog.csdn.net/qq_33330687/article/details/101479385
java进阶架构师
2020/10/23
7110
踩坑!JDK8中HashMap依然会死循环!
监控、链路追踪、日志这三者有何区别?
对于一个系统来说,监控、链路追踪、日志的这三者需求都是必然存在的,而有的时候我们会搞不清楚这三者相互之间是什么关系。我之前在做系统设计的时候也考虑过,是不是有必要引入那么多组件,毕竟如果这三者完全分开每一个一项的话,就有三个组件了(事实上就是:Prometheus+Grafana、Jaeger、ELK)。
java进阶架构师
2020/10/23
1.3K0
监控、链路追踪、日志这三者有何区别?
IDEA 调试技巧,比 Eclipse 强太多了!
公众号改版后文章乱序推荐,希望你可以点击上方“Java进阶架构师”,点击右上角,将我们设为★“星标”!这样才不会错过每日进阶架构文章呀。
java进阶架构师
2020/11/03
5810
IDEA 调试技巧,比 Eclipse  强太多了!
delete后加 limit是个好习惯么 ?
来源:blog.csdn.net/qq_39390545/article/details/107519747
猿天地
2020/11/04
7080
面试官问:MySQL 的自增 ID 用完了,怎么办?
公众号改版后文章乱序推荐,希望你可以点击上方“Java进阶架构师”,点击右上角,将我们设为★“星标”!这样才不会错过每日进阶架构文章呀。
java进阶架构师
2020/11/03
6550
面试官问:MySQL 的自增 ID 用完了,怎么办?
解决 idea 使用过程中让你觉得不爽的一些问题
来源:https://juejin.im/post/6854573211779579918
java进阶架构师
2020/10/23
5330
解决 idea 使用过程中让你觉得不爽的一些问题
最近做了一个搜索接口的优化,反复压测了四次,终于达到要求了
逻辑看似很简单,当初我也是这样认为的,于是预估5天完成,最后前前后后开发、联调、改bug直到上线差不多花了10天(当然这10天并不是只做这一件事情)。
java进阶架构师
2020/12/17
4140
最近做了一个搜索接口的优化,反复压测了四次,终于达到要求了
redis服务又出现卡死,又是一次不当使用,这个锅你背定了!
首先说下问题现象:内网sandbox环境API持续1周出现应用卡死,所有api无响应。
java进阶架构师
2020/12/17
6450
redis服务又出现卡死,又是一次不当使用,这个锅你背定了!
使用 IntelliJ IDEA 查看类图,内容极度舒适
最近正好也没什么可忙的,就回过头来鼓捣过去的知识点,到Servlet部分时,以前学习的时候硬是把从上到下的继承关系和接口实现记得乱七八糟。
java进阶架构师
2020/10/23
9970
使用 IntelliJ IDEA 查看类图,内容极度舒适
SpringBoot 整合 Quartz 实现 JAVA 定时任务的动态配置
来源:https://www.cnblogs.com/laoyeye/p/9352002.html老爷爷的博客园
java进阶架构师
2020/10/23
8630
SpringBoot 整合 Quartz 实现 JAVA 定时任务的动态配置
面试官问:BitMap了解么?在什么场景下用过?碰到过什么问题?
Bit-map的基本思想就是用一个bit位来标记某个元素对应的Value,而Key即是该元素。由于采用了Bit为单位来存储数据,因此在存储空间方面,可以大大节省。(PS:划重点 节省存储空间)
java进阶架构师
2020/12/17
1.2K0
面试官问:BitMap了解么?在什么场景下用过?碰到过什么问题?
王者荣耀为什么不使用微服务架构?
zhihu.com/question/359630395/answer/954452799
java进阶架构师
2020/10/23
1K0
王者荣耀为什么不使用微服务架构?
一个复杂系统的拆分改造实践!
公众号改版后文章乱序推荐,希望你可以点击上方“Java进阶架构师”,点击右上角,将我们设为★“星标”!这样才不会错过每日进阶架构文章呀。
java进阶架构师
2020/11/03
5370
一个复杂系统的拆分改造实践!
新技能 MyBatis 千万数据表,快速分页!
流式查询 指的是查询成功后不是返回一个集合而是返回一个迭代器,应用每次从迭代器取一条查询结果。流式查询的好处是能够降低内存使用。
java进阶架构师
2020/12/03
3710
新技能 MyBatis 千万数据表,快速分页!
SpringBoot 的@Value注解太强大了,用了都说爽!
在日常开发中,经常会遇到需要在配置文件中,存储 List 或是 Map 这种类型的数据。
java进阶架构师
2021/02/05
7570
SpringBoot 的@Value注解太强大了,用了都说爽!
SQL中delete后加 Limit是个好习惯么?
导读:在业务场景要求高的数据库中,对于单条删除和更新操作,在delete和update后面加limit 1绝对是个好习惯。比如,在删除执行中,第一条就命中了删除行,如果SQL中有limit 1;这时就return了,否则还会执行完全表扫描才return。效率不言而喻。
码农架构
2021/03/24
1.3K0
教程 | 在华为鸿蒙OS上尝鲜,第一个“hello world”
来源:https://my.oschina.net/u/169565/blog/4557279
java进阶架构师
2020/10/23
5800
教程 | 在华为鸿蒙OS上尝鲜,第一个“hello world”
实现全链路监控平台很难吗?Pinpoint、SkyWalking、Zipkin 选型对比
随着微服务架构的流行,服务按照不同的维度进行拆分,一次请求往往需要涉及到多个服务。互联网应用构建在不同的软件模块集上,这些软件模块,有可能是由不同的团队开发、可能使用不同的编程语言来实现、有可能布在了几千台服务器,横跨多个不同的数据中心。因此,就需要一些可以帮助理解系统行为、用于分析性能问题的工具,以便发生故障的时候,能够快速定位和解决问题。
java进阶架构师
2021/05/08
1.7K0
实现全链路监控平台很难吗?Pinpoint、SkyWalking、Zipkin 选型对比
某团面试题:String s = new String("111")会创建几个对象?
公众号改版后文章乱序推荐,希望你可以点击上方“Java进阶架构师”,点击右上角,将我们设为★“星标”!这样才不会错过每日进阶架构文章呀。
java进阶架构师
2021/05/08
6630
某团面试题:String s = new String("111")会创建几个对象?
推荐阅读
相关推荐
delete 后加 limit 是个好习惯么?!
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验