mysql - 我有千万条数据,表结构该如何设计?
PHP中文网
PHP中文网 2017-04-17 13:16:39
[MySQL讨论组]

假设我有 10,000,000 条数据,
所以数据一共有100 个类别
如果查询的场景通常是把所有类别的数据跨类别的都取出来,数据库该怎么设计比较好
A 是按类别分成 100 张表,查询的时候从这100张表分别查;
B 全部存在一个表中

请别说做分布式之类的方法。现在想的是程序部分的设计,还不涉及系统的架构。假设我就有一台服务器。
类型是个 int, 我目前担心的是,如果分成一百个表,同时查这 100 个表会不会很慢。

id flow_type_id state owner
1 85 2 100012

数据大概是这种感觉。

PHP中文网
PHP中文网

认证0级讲师

全部回复(1)
巴扎黑

mysql自身单表千万承载能力还是可以的。
不过你的详细的数据样本呢?就只有分类么?分类是字符串么?

id category name
1 cat1 name1
2 cat2 name2
select * from table where category in ('cat1','cat2')

update

flow_type_id增加索引后使用in查询速度还是很感人的。千万级无需考虑分表问题,即便需要联合stateowner查询设置三个字段为符合复合索引即可。

涉及到分表处理的话作为一个成熟的系统考虑中间件等架构级别的设计方案是必须的。比如mysql-proxy分表查询在其内部就已经完成,国产的OneProxy更是支持内部并行查询,这样的效率是不必担心的(加个中间件而已)

Ps:如果有条件,可以尝试一下PostgreSQL。

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号