红联Linux门户
Linux帮助

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

发布时间:2014-08-31 21:21:21来源:红联作者:小小295813080
[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 where table_schema = 'db_name' and table_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 where table_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 where table_schema='database_name' and table_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 where table_schema='database_name' and table_name='table_name';


http://www.magedu.com/
[font=宋体] [/font]
文章评论

共有 1 条评论

  1. huiteng 于 2014-09-01 09:33:46发表:

    学习下