欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL 超大表快速刪除方式

 更新時間:2022年08月24日 16:28:40   作者:小王格子  
這篇文章主要介紹了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ù)的方法詳解

    MySQL使用命令行備份數(shù)據(jù)的方法詳解

    由于長期使用測試環(huán)境的數(shù)據(jù)庫,時不時會有臟數(shù)據(jù)刪除不干凈,對此很需要一個實時將生產(chǎn)庫的數(shù)據(jù)定期備份一份,防止生產(chǎn)庫中會有臟數(shù)據(jù)進(jìn)來,所以本文給大家介紹了MySQL使用命令行備份數(shù)據(jù)的方法,需要的朋友可以參考下
    2024-02-02
  • MySql之視圖索引的具體使用

    MySql之視圖索引的具體使用

    MySql 視圖索引是一種基于視圖的索引,它允許在視圖上創(chuàng)建索引以提高查詢性能,本文主要介紹了MySql之視圖索引的具體使用,感興趣的可以了解一下
    2023-08-08
  • MySQL數(shù)據(jù)庫維護(hù)中監(jiān)控所用到的常用命令

    MySQL數(shù)據(jù)庫維護(hù)中監(jiān)控所用到的常用命令

    這篇文章主要介紹額MySQL監(jiān)控時常用的的幾個MySQL命令,需要的朋友可以收藏下
    2013-08-08
  • MySQL 5.7.9 服務(wù)無法啟動-“NET HELPMSG 3534”的解決方法

    MySQL 5.7.9 服務(wù)無法啟動-“NET HELPMSG 3534”的解決方法

    這篇文章主要介紹了MySQL 5.7.9 服務(wù)無法啟動-“NET HELPMSG 3534”的解決方法,需要的朋友可以參考下
    2016-12-12
  • Mysql auto_increment 重新計數(shù)(讓id從1開始)

    Mysql auto_increment 重新計數(shù)(讓id從1開始)

    當(dāng)清空一個表的時候,重新插入數(shù)據(jù),發(fā)現(xiàn)auto_increment屬性的字段計數(shù)不是從1開始的時候,可以使用以下命令
    2012-12-12
  • mysql入門之1小時學(xué)會MySQL基礎(chǔ)

    mysql入門之1小時學(xué)會MySQL基礎(chǔ)

    今天剛好看到了SYZ01的這篇mysql入門文章,感覺對于想學(xué)習(xí)mysql的朋友是個不錯的資料,腳本之家特分享一下,需要的朋友可以參考下
    2018-01-01
  • MySQL使用表鎖和行鎖的場景詳解

    MySQL使用表鎖和行鎖的場景詳解

    MySQL?Innodb?的鎖可以說是執(zhí)行引擎的并發(fā)基礎(chǔ)了,有了鎖才能保證數(shù)據(jù)的一致性。但你知道什么時候會用表鎖,什么時候會用行鎖嗎?本文就來和大家一起詳細(xì)聊聊
    2022-09-09
  • MySQL 不允許從遠(yuǎn)程訪問的解決方法

    MySQL 不允許從遠(yuǎn)程訪問的解決方法

    MySQL 不允許從遠(yuǎn)程訪問的原因有很多除了下面的方法,還有需要看服務(wù)器安全設(shè)置禁止訪問本機(jī)的3306端口。
    2010-03-03
  • MySQL中的IF語句使用小結(jié)

    MySQL中的IF語句使用小結(jié)

    在MySQL數(shù)據(jù)庫中,IF 語句是一種常見的條件控制語句,本文介紹了 MySQL 中 IF 語句的基本用法以及實際應(yīng)用場景,具有一定的參考價值,感興趣的可以了解一下
    2023-10-10
  • mysql分區(qū)功能詳解,以及實例分析

    mysql分區(qū)功能詳解,以及實例分析

    下面小編就為大家?guī)硪黄猰ysql分區(qū)功能詳解,以及實例分析。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-03-03

最新評論