linux查询mysql表里数据,linux精品之关于MySQL 查询表数据大小的总结

[font=Symbol]?[/font]一:关于[font=Courier New]mysql[/font][font=宋体]表数据大小[/font]

1.

2.我们知道[font=Courier New]mysql[/font][font=宋体]存储数据文件一般使用表空间存储[/font][font=Courier New] [/font]

3.当[font=Courier New]mysql[/font][font=宋体]使用[/font][font=Courier New]innodb[/font][font=宋体]存储引擎的时候,[/font][font=Courier New] [/font]

4.mysql[font=宋体]使用表存储数据分为共享表空间和独享表空间两种方式[/font][font=Courier New] [/font]

5.?[font=宋体]共享表空间:[/font][font=Courier New]Innodb[/font][font=宋体]的所有数据保存在一个单独的表空间里面,而这个表空间可以由很多个文件组成,一个表可以跨多个文件存在。[/font][font=Courier New] [/font]

6.所以其大小限制不再是文件大小的限制,而是其自身的限制[font=Courier New] [/font]

7.-->innodb[font=宋体]官方显示表空间的最大限制为[/font][font=Courier New]64TB [/font]

8.?[font=宋体]独享表空间:每个表的数据以一个单独的文件来存放,这个时候的单表限制,又变成文件系统的大小限制了[/font][font=Courier New] [/font]

9.在默认情况下,[font=Courier New]MySQL[/font][font=宋体]创建的[/font][font=Courier New]MyISAM[/font][font=宋体]表允许的最大尺寸为[/font][font=Courier New]4GB [/font]

[font=Symbol]?[/font][font=宋体]二:关于show table stauts\G;中显示内容的解释[/font]

1.Data_length: 150032--->表中数据的大小[font=Courier New] [/font]

2.Index_length: 183107584--->表的索引的大小[font=Courier New] [/font]

3.Data_free: 25238175744--->表空间的大小[font=Courier New] [/font]

1.data_Free :[font=宋体]如果是共享表空间[/font][font=Courier New] data_free [/font][font=宋体]是共享表空间的大小而非数据的大小。[/font][font=Courier New] [/font]

2.如果是独享表空间才是该表的剩余空间。[font=Courier New] [/font]

3.如果表是分区存储的,[font=Courier New]data_free [/font][font=宋体]就是一个近似值而非精确值所以此时需要查询[/font][font=Courier New] [/font]

4.select sum(data_free) from information_schema.partitions wheretable_schema='db_name'andtable_name='tab_name';

5.查询所有数据库的大小[font=Courier New] [/font]

6.1:use information_schema;

7.select concat(round(sum(data_length/1024/1024),2),'MB') as data from tables[font=宋体];[/font][font=Courier New] [/font]

8.2:select concat(round(sum(data_length/1024/1024),2),'MB') as data from tables wheretable_schema='database_name';

9.3: [font=宋体]查询指定表的大小[/font][font=Courier New] [/font]

10.select concat(round(sum(data_length/1024/1024),2),'MB') as data from tables wheretable_schema='database_name'andtable_name='table_name';

[font=Symbol]?[/font][font=宋体]三:判断mysql I/0 性能的一种方式(网络搜集供参考)[/font]

1.show global status like 'innodb_dblwr%'\G

2.如果[font=Courier New]innodb_dblwr_pages_writen/innodb_dblwr_writes[/font][font=宋体]远小于[/font][font=Courier New]64[/font][font=宋体]:[/font][font=Courier New]1[/font][font=宋体],说明磁盘写入压力不高[/font][font=Courier New] [/font]

3.show engine innodb status\G [font=宋体]查看缓冲池的方法。[/font][font=Courier New] [/font]

4.select table_name,data_length+index_length,table_rows from tables wheretable_schema='database_name'andtable_name='table_name';

http://www.magedu.com/

[font=宋体][/font]

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值