MySQL 超大表快速刪除方式
MySQL 超大表快速刪除
MySQL里面直接對大表執(zhí)行drop table刪除有可能導(dǎo)致MySQL Hang住,對業(yè)務(wù)造成影響。刪除超大表的前提是該表是獨(dú)立表空間,這樣刪除才有效。
表創(chuàng)建一個硬鏈接
# du -sh pay_bills.ibd? 175G ? ? ? ?pay_bills.ibd # 創(chuàng)建硬鏈接 # ln pay_bills.ibd pay_bills.ibd_hdlk
執(zhí)行表刪除
在Linux中,每個存儲文件都會有指向該文件的Inode Index,多個文件名可以通過相同Inode Index指向相同一個存儲文件。
如果該文件名引用的Inode Index上還被其他文件名引用,則只會刪除該文件名和Inode Index之間的引用
如果該文件名引用的Inode Index上沒有被其他文件名引用,則刪除該文件名和Inode Index之間的引用并刪除Inode Index指向的存儲文件。
實際上只是刪除了對 pay_bills.ibd 的一個文件引用,我們 pay_bills.ibd_hdlk 對物理文件的引用還是存在的,就不會執(zhí)行OS級別的刪除操作,IO波動不大,降低對MySQL的影響。
mysql> drop table pay_bills; Query OK, 0 rows affected (3.24 sec)
執(zhí)行文件刪除
安裝 truncate 工具
# yum install coreutils -y
執(zhí)行刪除腳本
#!/bin/bash TRUNCATE=/usr/bin/truncate # 從175G開始每次刪除2G,最后如果腳本truncate后還剩下部分文件,使用rm刪除 for i in `seq 175 -2 1`; do? ? $TRUNCATE -s ${i}G ?pay_bills.ibd_hdlk ? sleep 1 done rm -f pay_bills.ibd_hdlk
MySQL快速清空大表數(shù)據(jù)
項目初次上線,進(jìn)行性能測試造的數(shù)據(jù)量巨大,都是些不可用數(shù)據(jù),但又有一些是必須保留的,很多時候需要進(jìn)行系統(tǒng)性的清理數(shù)據(jù)或者是,將有用的數(shù)據(jù)篩選出來之后再插入到表中!保留表結(jié)構(gòu)或者重新建表(導(dǎo)出數(shù)據(jù)庫中的表結(jié)構(gòu)),重新執(zhí)行SQL語句。
MySQL刪除或清空表數(shù)據(jù)
清空表數(shù)據(jù)的五種方式
1、truncate–刪除所有數(shù)據(jù),保留表結(jié)構(gòu),不能撤銷還原
2、delete–是逐行刪除速度極慢,不適合大量數(shù)據(jù)刪除
3、drop–刪除表,數(shù)據(jù)和表結(jié)構(gòu)一起刪除
4、導(dǎo)出表結(jié)構(gòu),再次執(zhí)行一遍;
5、導(dǎo)出數(shù)據(jù)庫所有表結(jié)構(gòu),再次執(zhí)行一遍,清空所有表(與4一致)
清空表數(shù)據(jù)語法
truncate table 表名;(僅保留表結(jié)構(gòu),速度很快)
delete from 表名;
delete from 表名 where 列名="value ";
DROP `t_product_events` IF EXIST; CREATE TABLE `t_product_events` ( `id` bigint(20) UNSIGNED NOT NULL AUTO_INCREMENT COMMENT '事件ID', `level` int(11) NULL DEFAULT NULL, `product_id` bigint(20) NOT NULL COMMENT '產(chǎn)品類型ID', `identifier` varchar(64) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL, `name` varchar(64) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT '事件名稱', `description` varchar(256) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL COMMENT '事件描述', `type` int(11) NOT NULL COMMENT '事件類型,0:info(信息)、1:alert(告警)、2:error(故障)', `ref_id` int(11) UNSIGNED NULL DEFAULT 0 COMMENT '引入模板時有意義', `original_required` tinyint(2) NOT NULL, `update_required` tinyint(2) NOT NULL DEFAULT 0 COMMENT '是否是標(biāo)準(zhǔn)功能的必選事件,0:可選,1:必選', `custom` tinyint(2) NOT NULL COMMENT '0:模板導(dǎo)入,1:自定義', `method` varchar(128) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT '事件對應(yīng)的方法名稱(根據(jù)identifier生成)', `create_time` datetime(0) NOT NULL DEFAULT CURRENT_TIMESTAMP, `update_time` datetime(0) NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP(0), `ref` bigint(20) NULL DEFAULT NULL, `related` int(11) NULL DEFAULT 0 COMMENT '被預(yù)發(fā)布或者已發(fā)布關(guān)聯(lián)個數(shù)', `copyright` tinyint(2) NULL DEFAULT 0 COMMENT '是否發(fā)布過, 1 發(fā)布過 0未發(fā)布', `prerelease` tinyint(2) NULL DEFAULT 0 COMMENT '是否預(yù)發(fā)布過, 1 預(yù)發(fā)布過 0未預(yù)發(fā)布', PRIMARY KEY (`id`) USING BTREE, INDEX `idx_product_id`(`product_id`) USING BTREE COMMENT '查詢優(yōu)化' ) ENGINE = InnoDB AUTO_INCREMENT = 497560 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci COMMENT = '產(chǎn)品類型事件表' ROW_FORMAT = Compact;
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
MySQL數(shù)據(jù)庫維護(hù)中監(jiān)控所用到的常用命令
這篇文章主要介紹額MySQL監(jiān)控時常用的的幾個MySQL命令,需要的朋友可以收藏下2013-08-08MySQL 5.7.9 服務(wù)無法啟動-“NET HELPMSG 3534”的解決方法
這篇文章主要介紹了MySQL 5.7.9 服務(wù)無法啟動-“NET HELPMSG 3534”的解決方法,需要的朋友可以參考下2016-12-12Mysql auto_increment 重新計數(shù)(讓id從1開始)
當(dāng)清空一個表的時候,重新插入數(shù)據(jù),發(fā)現(xiàn)auto_increment屬性的字段計數(shù)不是從1開始的時候,可以使用以下命令2012-12-12mysql入門之1小時學(xué)會MySQL基礎(chǔ)
今天剛好看到了SYZ01的這篇mysql入門文章,感覺對于想學(xué)習(xí)mysql的朋友是個不錯的資料,腳本之家特分享一下,需要的朋友可以參考下2018-01-01