日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

MySQL单表数据量超1亿,根据 索引列 批量删除数据

發布時間:2024/1/18 数据库 30 豆豆
生活随笔 收集整理的這篇文章主要介紹了 MySQL单表数据量超1亿,根据 索引列 批量删除数据 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

我的場景:MySQL8有個表數據量超1億,然后我要根據某個例(一對多)刪除數據,

我直接用:delete from 表 where 字段 in (select 其他表)? ? ?條件用in的方式執行報錯

[Err] 1206 - The total number of locks exceeds the lock table size

因為一次性要刪除數據量太多了,每個都加了行鎖,所以報錯了,而且這樣效率也不高,不穩定。

所以寫了個存儲過程的方式來刪除數據:

概述:

1.先查出刪除條件 in 的范圍值

2.將in值存儲到游標,然后一個一個循環

3.根據循環值 刪除表數據(一對多,索引列)

?

這樣不是一次性刪除,不用擔心mysql表行鎖的問題,運行也穩定不會出錯,效率也是最高的

CREATE DEFINER=`root`@`%` PROCEDURE `clean_old_defectData`() BEGIN#Routine body goes here...DECLARE COILNO VARCHAR(255);DECLARE COILNO_CURSOR_COUNT INT DEFAULT 1;-- 先查出刪除條件 in 里面的值(我的是DELIVERYCOILNO),放到游標里DECLARE COILNO_CURSOR CURSOR FORSELECT DELIVERYCOILNO FROM qualitydb.t_sg_mat_info WHERE STARTTIME BETWEEN '2021-01-01' AND '2021-07-01';-- 設置循環的次數(游標的大小)DECLARE EXIT HANDLER FOR NOT FOUND SET COILNO_CURSOR_COUNT = 0;OPEN COILNO_CURSOR;-- 循環游標WHILE COILNO_CURSOR_COUNT <> 0 DOFETCH COILNO_CURSOR INTO COILNO;-- INSERT INTO qualitydb.test(val2) VALUES(COILNO);-- 刪除表數據,我這里有兩個表要刪除DELETE FROM qualitydb.t_sg_defect_info WHERE DELIVERYCOILNO = COILNO;DELETE FROM qualitydb.t_sg_defect_quality_result WHERE coil_id = COILNO;END WHILE;CLOSE COILNO_CURSOR; END

總結

以上是生活随笔為你收集整理的MySQL单表数据量超1亿,根据 索引列 批量删除数据的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。