mysql數(shù)據(jù)庫(kù)空間統(tǒng)計(jì)sql代碼示例
說(shuō)明
INFORMATION_SCHEMA Table Reference 表參考
information_schema是MySQL中的一個(gè)特殊數(shù)據(jù)庫(kù),它存儲(chǔ)了關(guān)于所有其他數(shù)據(jù)庫(kù)的元數(shù)據(jù)信息。 這些元數(shù)據(jù)包括數(shù)據(jù)庫(kù)名、表名、列的數(shù)據(jù)類型、訪問(wèn)權(quán)限等。通過(guò)查詢information_schema,用戶可以獲取到關(guān)于數(shù)據(jù)庫(kù)結(jié)構(gòu)的詳細(xì)信息,這對(duì)于數(shù)據(jù)庫(kù)管理和優(yōu)化非常有幫助。例如,可以通過(guò)查詢information_schema來(lái)查看表的索引信息、視圖定義、存儲(chǔ)過(guò)程和函數(shù)的信息等。此外,由于information_schema中的表都是只讀的,它們實(shí)際上可以被視為視圖,因此用戶無(wú)法直接修改這些數(shù)據(jù),保證了元數(shù)據(jù)的完整性。
一、數(shù)據(jù)庫(kù)存儲(chǔ)代碼
請(qǐng)注意
如果啟用了innodb_read_only系統(tǒng)變量,ANALYZE TABLE可能會(huì)失敗,因?yàn)樗鼰o(wú)法更新使用InnoDB的數(shù)據(jù)字典中的統(tǒng)計(jì)表。對(duì)于更新鍵分布的ANALYZE TABLE操作,即使操作更新表本身(例如,如果它是一個(gè)MyISAM表),也可能發(fā)生失敗。要獲取更新的分布統(tǒng)計(jì)信息,可以設(shè)置information_schema_stats_expiry=0。
代碼如下(GB)(示例):以下 是GB的統(tǒng)計(jì)
查詢一個(gè)實(shí)例的所有庫(kù)的數(shù)據(jù)的大小總和
select coalesce(table_schema, '合計(jì)') as table_schema , concat(round(sum(data_length/1024/1024/1024),2),'GB') as data_length_GB, concat(round(sum(index_length/1024/1024/1024),2),'GB') as index_length_GB , concat(round(sum(index_length/1024/1024/1024),2)+round(sum(data_length/1024/1024/1024),2),'GB') as tal_GB from information_schema.tables t where table_Type='BASE TABLE' and table_schema not in ('document','mysql','performance_schema','sys') group by table_schema
代碼如下(MB)(示例): MB
查詢一個(gè)實(shí)例的所有庫(kù)的數(shù)據(jù)的大小總和
select coalesce(table_schema, '合計(jì)') as table_schema, concat(round(sum(data_length/1024/1024),2),'MB') as data_length_MB, concat(round(sum(index_length/1024/1024),2),'MB') as index_length_MB , concat(round(sum(index_length/1024/1024),2)+round(sum(data_length/1024/1024),2),'MB') as tal_MB from information_schema.tables t where table_Type='BASE TABLE' and table_schema not in ('document','mysql','performance_schema','sys') group by table_schema WITH ROLLUP order by round(sum(data_length/1024/1024),2) desc
二、查詢某個(gè)數(shù)據(jù)庫(kù)的所有表的 代碼
SELECT TABLE_NAME, ENGINE, VERSION, ROW_FORMAT, TABLE_ROWS, AVG_ROW_LENGTH, DATA_LENGTH, MAX_DATA_LENGTH, INDEX_LENGTH, DATA_FREE, AUTO_INCREMENT, CREATE_TIME, UPDATE_TIME, CHECK_TIME, TABLE_COLLATION, CHECKSUM, CREATE_OPTIONS, TABLE_COMMENT FROM INFORMATION_SCHEMA.TABLES WHERE table_schema = 'db_name' [AND table_name LIKE 'wild'] SHOW TABLE STATUS FROM db_name [LIKE 'wild']
The following statements are equivalent:
SELECT TABLE_NAME, TABLE_TYPE FROM INFORMATION_SCHEMA.TABLES WHERE table_schema = 'db_name' [AND table_name LIKE 'wild'] SHOW FULL TABLES FROM db_name [LIKE 'wild']
三、列出所有已經(jīng)產(chǎn)生碎片的表
-- 列出所有已經(jīng)產(chǎn)生碎片的表 ('information_schema', 'mysql'這兩個(gè)庫(kù)是mysql自帶的庫(kù)) select table_schema db, table_name, data_free, engine, table_rows, data_length+index_length length from information_schema.tables where table_schema not in ('information_schema', 'mysql') and data_free > 0 ORDER BY data_free desc
處理表碎片
alter table gd_channel_app_retention engine=innodb;
note:這個(gè)語(yǔ)句處理碎片空間其實(shí)是先復(fù)制現(xiàn)有數(shù)據(jù)表 然后刪除舊的數(shù)據(jù)表 。如果這個(gè)表占用空間巨大,還是直接遷移數(shù)據(jù)吧。
https://dev.mysql.com/doc/refman/8.0/en/information-schema-tables-table.html
總結(jié)
information_schema用于存儲(chǔ)數(shù)據(jù)庫(kù)元數(shù)據(jù),本文sql 主要是 MySQL系統(tǒng)庫(kù)之information_schema的實(shí)現(xiàn),
- 查詢數(shù)據(jù)庫(kù)結(jié)構(gòu):information_schema 可用于查詢數(shù)據(jù)庫(kù)、表、列、索引、外鍵、觸發(fā)器等對(duì)象的結(jié)構(gòu)信息。
- 權(quán)限管理:可以使用 information_schema 查詢用戶和權(quán)限信息,以確保正確的訪問(wèn)控制和權(quán)限設(shè)置。
- 性能優(yōu)化:information_schema 提供有關(guān)索引、表大小、表引擎等性能相關(guān)信息,這對(duì)于性能優(yōu)化很有幫助。
- 查詢執(zhí)行計(jì)劃:可以查詢 information_schema 獲取查詢執(zhí)行計(jì)劃,以了解查詢?nèi)绾伪粓?zhí)行。
到此這篇關(guān)于mysql數(shù)據(jù)庫(kù)空間統(tǒng)計(jì)sql的文章就介紹到這了,更多相關(guān)mysql 數(shù)據(jù)庫(kù)空間統(tǒng)計(jì)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- MySQL統(tǒng)計(jì)今日生成create_time的數(shù)據(jù)量的方法小結(jié)
- MySQL數(shù)據(jù)庫(kù)統(tǒng)計(jì)函數(shù)COUNT的使用及說(shuō)明
- mysql按天/小時(shí)/半小時(shí)/N分鐘/分鐘進(jìn)行數(shù)據(jù)分組統(tǒng)計(jì)功能
- MySQL如何使用DATE_FORMAT()對(duì)查詢結(jié)果按日、周、月分組統(tǒng)計(jì)
- MYSQL數(shù)據(jù)庫(kù)查詢按日期分組統(tǒng)計(jì)詳細(xì)代碼
- MySQL統(tǒng)計(jì)時(shí)間差的平均值方式
- MySQL實(shí)現(xiàn)按分秒統(tǒng)計(jì)數(shù)據(jù)量方式
相關(guān)文章
mysql 5.7安裝 MySQL 服務(wù)無(wú)法啟動(dòng)但是服務(wù)沒(méi)有報(bào)告任何錯(cuò)誤
這篇文章主要介紹了mysql 5.7安裝 MySQL 服務(wù)無(wú)法啟動(dòng)但是服務(wù)沒(méi)有報(bào)告任何錯(cuò)誤的相關(guān)資料,需要的朋友可以參考下2017-04-04數(shù)據(jù)結(jié)構(gòu)-樹(三):多路搜索樹B樹、B+樹
這篇文章主要介紹了多路搜索樹B樹、B+樹,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04教會(huì)你完全搞定MySQL數(shù)據(jù)庫(kù) 輕松八句話
只要掌握下面的方法,就基本上能搞定mysql數(shù)據(jù)庫(kù)。2010-09-09MySQL系列之十 MySQL事務(wù)隔離實(shí)現(xiàn)并發(fā)控制
今天的內(nèi)容就和大家聊一聊MySQL數(shù)據(jù)庫(kù)中關(guān)于MySQL事務(wù)隔離實(shí)現(xiàn)并發(fā)控制的問(wèn)題,主要是基于鎖實(shí)現(xiàn)控制技術(shù)2021-07-07MySQL實(shí)現(xiàn)當(dāng)前數(shù)據(jù)表的所有時(shí)間都增加或減少指定的時(shí)間間隔(推薦)
這篇文章主要介紹了MySQL實(shí)現(xiàn)當(dāng)前數(shù)據(jù)表的所有時(shí)間都增加或減少指定的時(shí)間間隔,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-02-02Mysql5.7.11在windows10上的安裝與配置(解壓版)
本文分為三大步給大家介紹Mysql5.7.11解壓版在windows10上的安裝與配置,另外還給大家?guī)?lái)了mysql5.7.11服務(wù)無(wú)法啟動(dòng),錯(cuò)誤代碼3534的解決方案,非常不錯(cuò),有需要的朋友參考下2016-08-08詳解Mysql數(shù)據(jù)庫(kù)date, datetime類型設(shè)置0000-00-00默認(rèn)值(default)報(bào)錯(cuò)問(wèn)題
這篇文章主要介紹了詳解Mysql數(shù)據(jù)庫(kù)date, datetime類型設(shè)置0000-00-00默認(rèn)值(default)報(bào)錯(cuò)問(wèn)題,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2019-01-01