数据库中有一张叫后宫佳丽的表,每天都有几百万新的小姐姐插到表中,光阴荏苒,夜以继日,日久生情,时间长了,表中就有了几十亿的小姐姐数据。


如何锁住数据库中几十亿小姐姐?_java图片来自 Pexels

看到几十亿的小姐姐,每到晚上,我可愁死了,这么多小姐姐,我翻张牌呢?


办法当然是精兵简政,删除那些 age>18 的,给年轻的小姐姐们留位置...


于是我在数据库中添加了一个定时执行的小程序,每到周日,就自动运行如下的脚本:

delete from `后宫佳丽` where age>18

一开始还自我感觉良好,后面我就发现不对了,每到周日,这个脚本一执行就是一整天。


运行的时间有点长是小事,重点是这大好周日,我再想读这张表的数据,怎么也读不出来了,怎是一句空虚了得,我好难啊......

为什么?编不下去了,真实背景是公司中遇到的一张有海量数据表,每次一旦执行历史数据的清理,我们的程序就因为读不到这张表的数据,疯狂地报错。

后面一查了解到,原来是因为定时删除的语句设计不合理,导致数据库中数据由行锁(Row lock)升级为表锁(Table lock)了!