首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在MySql数据库中存储大量的记录?

如何在MySql数据库中存储大量的记录?
EN

Stack Overflow用户
提问于 2014-04-07 09:49:01
回答 1查看 2.7K关注 0票数 2

我有一个表,其中包含一个用户id的大约2500行。对于每个用户id,将有相同的行数。如果用户数量增加,恐怕行数会很大。

你能建议我怎么做吗?是为不同的用户使用不同的表,还是为所有的用户使用单一的表。另一件事是,在一个表中有多少行/列是最大的限制?

我的数据库如下所示:

for User1

代码语言:javascript
复制
id ----   col1 
1  ----  value1
2  ----  value2

.

2500 .值2500

for User2

代码语言:javascript
复制
id ----  col1 ...
1  ----  value1
2  ----  value2

.

2500 .值2500

同样,对于假设100万用户,它也将继续存在。

因此,我应该为每个用户创建单独的表,还是应该创建一个包含所有记录的表。

EN

回答 1

Stack Overflow用户

发布于 2014-04-07 09:51:08

用一张你自己的桌子。MySQL可以轻松地处理数十亿或行数据。有了一些很好的索引,您的性能也应该相当好。

这并不是说你不应该确保你有好的表格设计,但你也不应该担心处理你认为可能是大量数据的东西--事实上,这可能是数据集的海洋中的一种下降。

列的数量并没有太大的差别,行大小可能会增加硬盘访问它们所需的时间(根据我读过的几篇文章),但同时,您必须有一个非常大的行才能真正注意到数千个查询之间的差异。

至于好的结构,它真的取决于你将需要如何使用它。如果要执行许多不同的聚合函数,请确保您有一个允许它的表。如果您只需要几个特定的查询,最好创建一个特定于报表的表来聚合数据,比如每天一次。

编辑:关于行数实际限制的说明:

http://dev.mysql.com/doc/refman/5.1/en/source-configuration-options.html

MyISAM存储引擎支持每个表2^32行,但您可以使用- with - table选项构建MySQL,从而使每个表最多支持2^64行。

http://dev.mysql.com/doc/refman/5.1/en/innodb-restrictions.html

InnoDB存储引擎似乎没有对行数的限制,但它对表大小的限制是64 terra字节。有多少行适合这一点取决于每一行的大小。

票数 7
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/22908895

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档