zoukankan      html  css  js  c++  java
  • mysql查看当前所有数据库中的表大小和元信息information_schema

    查看所有mysql数据库表和索引大小

    mysql查看当前所有的数据库和索引大小

    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_length desc;

    mysql查看当前某个数据库和数据库下所有的表的大小

    select table_name, concat(truncate(data_length/1024/1024,2),' mb') as data_size,
    concat(truncate(index_length/1024/1024,2),' mb') as index_size
    from information_schema.tables where table_schema = 'mysql'
    group by table_name
    order by data_length desc;

    mysql查看当前某个数据库和某个表的大小

    select table_name, concat(truncate(data_length/1024/1024,2),' mb') as data_size,
    concat(truncate(index_length/1024/1024,2),' mb') as index_size
    from information_schema.tables where table_schema = 'mysql'
    and table_name=xxx;

    information_schema数据库表

    information_schema数据库是MySQL自带的,它提供了访问数据库元数据的方式。什么是元数据呢?元数据是关于数据的数据,如数据库名或表名,列的数据类型,或访问权限等。有些时候用于表述该信息的其他术语包括“数据词典”和“系统目录”。
    在MySQL中,把 information_schema 看作是一个数据库,确切说是信息数据库。其中保存着关于MySQL服务器所维护的所有其他数据库的信息。如数据库名,数据库的表,表栏的数据类型与访问权 限等。在INFORMATION_SCHEMA中,有数个只读表。它们实际上是视图,而不是基本表,因此,你将无法看到与之相关的任何文件。

    information_schema数据库表说明:

    SCHEMATA表:提供了当前mysql实例中所有数据库的信息。是show databases的结果取之此表。

    TABLES表:提供了关于数据库中的表的信息(包括视图)。详细表述了某个表属于哪个schema,表类型,表引擎,创建时间等信息。是show tables from schemaname的结果取之此表。

    COLUMNS表:提供了表中的列信息。详细表述了某张表的所有列以及每个列的信息。是show columns from schemaname.tablename的结果取之此表。

    STATISTICS表:提供了关于表索引的信息。是show index from schemaname.tablename的结果取之此表。

    USER_PRIVILEGES(用户权限)表:给出了关于全程权限的信息。该信息源自mysql.user授权表。是非标准表。

    SCHEMA_PRIVILEGES(方案权限)表:给出了关于方案(数据库)权限的信息。该信息来自mysql.db授权表。是非标准表。

    TABLE_PRIVILEGES(表权限)表:给出了关于表权限的信息。该信息源自mysql.tables_priv授权表。是非标准表。

    COLUMN_PRIVILEGES(列权限)表:给出了关于列权限的信息。该信息源自mysql.columns_priv授权表。是非标准表。

    CHARACTER_SETS(字符集)表:提供了mysql实例可用字符集的信息。是SHOW CHARACTER SET结果集取之此表。

    COLLATIONS表:提供了关于各字符集的对照信息。

    COLLATION_CHARACTER_SET_APPLICABILITY表:指明了可用于校对的字符集。这些列等效于SHOW COLLATION的前两个显示字段。

    TABLE_CONSTRAINTS表:描述了存在约束的表。以及表的约束类型。

    KEY_COLUMN_USAGE表:描述了具有约束的键列。

    ROUTINES表:提供了关于存储子程序(存储程序和函数)的信息。此时,ROUTINES表不包含自定义函数(UDF)。名为“mysql.proc name”的列指明了对应于INFORMATION_SCHEMA.ROUTINES表的mysql.proc表列。

    VIEWS表:给出了关于数据库中的视图的信息。需要有show views权限,否则无法查看视图信息。

    TRIGGERS表:提供了关于触发程序的信息。必须有super权限才能查看该表

    TABLES表

    字段 含义
    Table_catalog 数据表登记目录
    Table_schema 数据表所属的数据库名
    Table_name 表名称
    Table_type 表类型[system view|base table]
    Engine 使用的数据库引擎[MyISAM|CSV|InnoDB]
    Version 版本,默认值10
    Row_format 行格式[Compact|Dynamic|Fixed]
    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 表的注释、备注

    详细说明:

    row_format:
    若一张表里面不存在varchar、text以及其变形、blob以及其变形的字段的话,那么张这个表其实也叫静态表,即该表的row_format是fixed,就是说每条记录所占用的字节一样。其优点读取快,缺点浪费额外一部分空间。
    若一张表里面存在varchar、text以及其变形、blob以及其变形的字段的话,那么张这个表其实也叫动态表,即该表的row_format是dynamic,就是说每条记录所占用的字节是动态的。其优点节省空间,缺点增加读取的时间开销。
    所以,做搜索查询量大的表一般都以空间来换取时间,设计成静态表。
    row_format还有其他一些值:
    DEFAULT | FIXED | DYNAMIC | COMPRESSED | REDUNDANT | COMPACT
    修改行格式
    ALTER TABLE table_name ROW_FORMAT = DEFAULT
    修改过程导致:
    fixed--->dynamic: 这会导致CHAR变成VARCHAR
    dynamic--->fixed: 这会导致VARCHAR变成CHAR
     
    data_free
    每当MySQL从你的列表中删除了一行内容,该段空间就会被留空。而在一段时间内的大量删除操作,会使这种留空的空间变得比存储列表内容所使用的空间更大。
    当MySQL对数据进行扫描时,它扫描的对象实际是列表的容量需求上限,也就是数据被写入的区域中处于峰值位置的部分。如果进行新的插入操作,MySQL将尝试利用这些留空的区域,但仍然无法将其彻底占用。
    1.查询数据库空间碎片:
    select table_name,data_free,engine from information_schema.tables where table_schema='yourdatabase';
    2.对数据表优化:
    optimeze table `table_name`;
  • 相关阅读:
    Sum Root to Leaf Numbers 解答
    459. Repeated Substring Pattern
    71. Simplify Path
    89. Gray Code
    73. Set Matrix Zeroes
    297. Serialize and Deserialize Binary Tree
    449. Serialize and Deserialize BST
    451. Sort Characters By Frequency
    165. Compare Version Numbers
    447. Number of Boomerangs
  • 原文地址:https://www.cnblogs.com/wqbin/p/11887841.html
Copyright © 2011-2022 走看看