美文网首页
information_schem table表使用

information_schem table表使用

作者: 夏树的宝马 | 来源:发表于2017-06-05 18:56 被阅读58次
  1. 获取所有表结构(TABLES)
    SELECT * FROM information_schema.TABLES WHERE TABLE_SCHEMA='数据库名'; TABLES表:提供了关于数据库中的表的信息(包括视图)。详细表述了某个表属于哪个schema,表类型,表引擎,创建时间等信息。各字段说明如下:
    字段 含义
    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;

参考:
http://wenku.baidu.com/link?url=MtPZrab7kbciXsBAjia4w0JUE3aFCtOj9fu_2zXVE5JW6k8UHaFCl6ppGE89HPMUFmLSMTjmp2rqbIMcSXBIJ11LIlxzDYJH1qLHZpNdqYu
http://blog.sina.com.cn/s/blog_70b9a0e90101cmdz.html
http://www.2cto.com/database/201208/144994.html


例子

  1. tables表的使用,
    这个表记录了mysql中每一个库的一些重要信息,
    查询某个库的表的所有行数
    select table_name,table_rows from tables
    where TABLE_SCHEMA = 'oa'
    order by table_rows desc;

相关文章

  • information_schem table表使用

    获取所有表结构(TABLES)SELECT * FROM information_schema.TABLES ...

  • information_schem column表使用

    转载便于记录 例子 :比如,我现在想查询某一个库里面的那些表包含某一个特殊的列名;select a.table_n...

  • mysql---修改表结构

    使用ALTER TABLE修改表结构 1) 修改表名称 ALTER TABLE <表名> RENAME <新表名>...

  • oracle merge into常见用法

    table_a表与table_b有关联关系 不在库中的数据判断是否在table_a表中,存在更新否则插入 使用虚表...

  • DEFINITION ONLY关键字

    在sql建表时,使用create table table_name as select ... definitio...

  • Sqlalchemy 中间表的建立

    第一种:使用Table()函数构造形式。 注意:如果table构造出的表仅仅能作为其他两个表的连接查询中间表使用,...

  • TRUNCATE

    当清空一个表,如果使用 delete from table 报错 可以使用 TRUNCATE TABLE [TAB...

  • 四、重命名表

    更改一个或多个表,我们使用RENAME TABLE语句如下: RENAME TABLE old_table_nam...

  • create table as select

    创建表使用 as select 如下图: 总结:不建议使用create table as select。

  • 数据库内外连接区别

    table1表中数据如下: ​ table2表中数据如下: ​ 使用内连接的sql语句及结果如下: select ...

网友评论

      本文标题:information_schem table表使用

      本文链接:https://www.haomeiwen.com/subject/thxwfxtx.html