我有一个表,其中包含一个用户id的大约2500行。对于每个用户id,将有相同的行数。如果用户数量增加,恐怕行数会很大。
你能建议我怎么做吗?是为不同的用户使用不同的表,还是为所有的用户使用单一的表。另一件事是,在一个表中有多少行/列是最大的限制?
我的数据库如下所示:
for User1
id ---- col1
1 ---- value1
2 ---- value2.
2500 .值2500
for User2
id ---- col1 ...
1 ---- value1
2 ---- value2.
2500 .值2500
同样,对于假设100万用户,它也将继续存在。
因此,我应该为每个用户创建单独的表,还是应该创建一个包含所有记录的表。
发布于 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字节。有多少行适合这一点取决于每一行的大小。
https://stackoverflow.com/questions/22908895
复制相似问题