网站首页 > 技术文章 正文
当单表数据过多查询变慢时,我们时常需要观察单表的大小及内存情况,并考虑是否进行分表归档。
以mysql为例,查询操作如下:
第一步:
use information_schema;
第二步:
select TABLE_ROWS '总行数',
concat(round(sum(DATA_LENGTH/1024/1024), 2),'M') as '表大小',
concat(round(sum(INDEX_LENGTH/1024/1024), 2),'M') as '索引大小',
concat(round(sum(DATA_LENGTH/TABLE_ROWS/1024), 2),'KB') as '单行大小'
from TABLES where table_schema='你的数据库名称' and table_name='你的表名';
mysql单表支持最大的条数,可以根据单行大小计算。
假设你的表单行数据大小为1KB。则在B+树索引层级为3层时,能存储的行记录上限为21,902,400。若为2KB,则上限在1000W条左右。当然,很多情况下我们不需要达到这么多就需要拆分表了。
?
猜你喜欢
- 2024-10-27 MySQL左查询最全介绍(sql 左查询)
- 2024-10-27 mysql查询指定父级下所有子级(mysql根据子节点查父)
- 2024-10-27 MySQL数据库入门(七)多表查询及大量练习
- 2024-10-27 mysql进行数据查询(单表查询)(mysql 查询数据表)
- 2024-10-27 【执行计划】MySQL如何执行查询?(mysql执行查询语句)
- 2024-10-27 MySQL查询列必须和group by字段一致吗?
- 2024-10-27 查看MySQL所有数据库列表(mysql怎么查看数据库列表)
- 2024-10-27 「mysql」mysql调优时必须掌握的慢查询语句排查命令
- 2024-10-27 有一张1000W 数据记录的表,主键id自增,如何随机抽取10条记录?
- 2024-10-27 MySQL进阶实战7,查询的执行过程(mysql查询机制)
- 最近发表
- 标签列表
-
- cmd/c (57)
- c++中::是什么意思 (57)
- sqlset (59)
- ps可以打开pdf格式吗 (58)
- phprequire_once (61)
- localstorage.removeitem (74)
- routermode (59)
- vector线程安全吗 (70)
- & (66)
- java (73)
- org.redisson (64)
- log.warn (60)
- cannotinstantiatethetype (62)
- js数组插入 (83)
- resttemplateokhttp (59)
- gormwherein (64)
- linux删除一个文件夹 (65)
- mac安装java (72)
- reader.onload (61)
- outofmemoryerror是什么意思 (64)
- flask文件上传 (63)
- eacces (67)
- 查看mysql是否启动 (70)
- java是值传递还是引用传递 (58)
- 无效的列索引 (74)