MySQL查看數據庫、表占用磁盤大小


原文地址:請優先查看!請優先查看!
Mysql——查看數據庫,表占用磁盤大小
MySQL查看數據庫或表磁盤占用空間
mysql遇見Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggre的問題

1、查詢所有數據庫占用磁盤空間大小

select
TABLE_SCHEMA,
concat(truncate(sum(data_length)/1024/1024,2),' MB') as data_size,
concat(truncate(sum(index_length)/1024/1024,2),'MB') as index_size
from information_schema.tables
group by TABLE_SCHEMA
ORDER BY data_size desc;

2、查詢單個庫中所有表占用磁盤大小

select concat(truncate(sum(data_length)/1024/1024,2),'MB') as data_size,
         concat(truncate(sum(max_data_length)/1024/1024,2),'MB') as max_data_size,
         concat(truncate(sum(data_free)/1024/1024,2),'MB') as data_free,
         concat(truncate(sum(index_length)/1024/1024,2),'MB') as index_size
  from information_schema.tables
where TABLE_SCHEMA = 'databasename'; # databasename 具體庫名

3、查看單個庫占用磁盤空間大小

# 單位GB
SELECT concat( round( sum( data_length ) / ( 1024 * 1024 * 1024 ), 6 ), 'GB' ) AS 'Total Data Size' 
FROM information_schema.TABLES 
WHERE table_schema LIKE 'database name';

4、查看單個表占用磁盤空間大小

select concat(truncate(sum(data_length)/1024/1024,2),'MB') as data_size,
         concat(truncate(sum(max_data_length)/1024/1024,2),'MB') as max_data_size,
         concat(truncate(sum(data_free)/1024/1024,2),'MB') as data_free,
         concat(truncate(sum(index_length)/1024/1024,2),'MB') as index_size
  from information_schema.tables
where TABLE_NAME = 'tablename'; # tablename 具體表名

5、查看單個數據庫中所有表的信息

SELECT
    concat( table_schema, '.', table_name ) AS 'Table Name',
    table_rows AS 'Number of Rows',
    concat( round( data_length / ( 1024 * 1024 * 1024 ), 6 ), ' G' ) AS 'Data Size',
    concat( round( index_length / ( 1024 * 1024 * 1024 ), 6 ), ' G' ) AS 'Index Size',
    concat( round( ( data_length + index_length ) / ( 1024 * 1024 * 1024 ), 6 ), ' G' ) AS 'Total' 
FROM
    information_schema.TABLES W 
WHERE
    table_schema LIKE 'database name';

6、查看索引空間

SELECT CONCAT( ROUND( SUM( index_length ) / ( 1024 * 1024 * 1024 ), 6 ), ' GB' ) AS 'Total Index Size' 
FROM information_schema.TABLES 
WHERE table_schema LIKE 'dabatase name';

7、使用optimize命令

optimize table tb_report_inventory;

使用的時間比較長,需要耐心等待。

注意:optimize執行時會將表鎖住,所以不要在高峰期使用。也不要經常使用,每月一次就足夠了

問題

若執行 2、查詢單個庫中所有表磁盤占用大小出現以下報錯:

Expression #2 of SELECT list is not in GROUP BY clause and contains
nonaggregated column ‘sss.month_id’ which is not functionally
dependent on columns in GROUP BY clause; this is incompatible with
sql_mode=only_full_group_by

解決方法一:
此方法只是臨時解決,重啟mysql服務器會還原。

打開navcat,

用sql查詢:

select @@global.sql_mode

查詢出來的值為:

ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION

去掉ONLY_FULL_GROUP_BY,重新設置值。

set @@global.sql_mode
=’STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION’;

解決方法二:

成功的步驟:

打開文件

sudo vim /etc/mysql/conf.d/mysql.cnf

滾動到文件底部復制並粘貼

[mysqld]
sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION

到文件的底部

保存並退出輸入模式

sudo service mysql restart

重啟MySQL。
完成!


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM