博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
mysql单表体积和一个库设计多少张表为妥
阅读量:5925 次
发布时间:2019-06-19

本文共 868 字,大约阅读时间需要 2 分钟。

这篇文章来自于看博客园一个园友的分享经历,原文:http://www.cnblogs.com/qqloving/p/3427138.html

 

他不清楚mysql一个库里面分多少张表合适,他一个库分了8000张表。于是我看了,忍不住作答。

 

于是以个人随笔的形式给自己做知识备忘吧。

 

1、单表体积多大的时候需要分表

 

曾经看过一个博客,分析到什么情况下需要分表。

单表形式访问(也就是对这个表的访问不涉及到join联合查询):单个表的体积大于2g的时候。或者说,单个表的行数达到一千万的时候。

两表jion:表的体积大于2G或行数大于500W。

 

在赶集网石展提到的分享中,纯int行不能超过1000万行,含char类型的字段不能超过500万行。与曾经看过文章提到的1000万和500万很相似。难道这是一个瓶颈值吗?

 

2、单个库控制多少张表为妥

听过赶集网的一个dba的分享视频。他从中提到,mysql的单库表数量不要超过300-400张表。这个我也没试过。不过我想应该是他经验之谈吧。
为什么一个库不能很多张表。我的理解是,mysql一个数据库就是磁盘上一个文件夹。那么里面一张表就需要一个文件记录(像myisam类型的是需要三个文件分别记录表结构,记录索引、记录表数据)。
分8000张表,假设是myisam,则需要8000*3个文件。
操作系统对一个目录有文件数限制,当文件数量太多的时候,查找文件的速度就会慢,所以我们经常见到的上传的图片不会全部放到一个文件夹,一般是按照年月日来生成文件夹。
当然,网友提到表的是innodb类型。
innodb类型有两种方式存储数据:共享表和独享表
独享,Innodb_file_per_table,每个表的数据都对应存储在一个文件中
共享,一个库下面所有的innodb类型表数据都存储在一个文件中。
mysql数据全部放到一个文件中去了,当数据量超过一定额度,又会新生成一个数据文件来存储。

 

 

 

转载于:https://www.cnblogs.com/wangtao_20/p/3428277.html

你可能感兴趣的文章
LVS负载均衡-NET、DR模式配置
查看>>
saltstack的安装(转载连接)
查看>>
解决windows系统80端口被占用问题
查看>>
文本文档TXT每行开头结尾加内容批处理代码
查看>>
Tomcat详解
查看>>
10分钟采集凡客最新的省、市、区、邮政编码和电话区号(附源码)
查看>>
【Linux】IPC-消息队列
查看>>
【Python】猜数小游戏(文件操作)
查看>>
(装载)C#中AppDomain.CurrentDomain.BaseDirectory与Application.StartupPath的区别
查看>>
php的几种运行模式CLI、CGI、FastCGI、mod_php
查看>>
[原创]同一个Tomcat,配置多个context、多个Host
查看>>
MyEclipse的Git配置
查看>>
Beta版本发布报告
查看>>
剑指offer-面试题13.在O(1)时间删除链表节点
查看>>
关于清晰讲解linux正则表达式的博文分享
查看>>
oslo.config资源
查看>>
ext 浅谈类的实例
查看>>
shell printf命令:格式化输出语句
查看>>
snmpd服务无法更改默认端口
查看>>
centos 7.x systemd service 配置方法整理
查看>>