MySQL社区

 找回密码
 注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

搜索
查看: 19453|回复: 8
打印 上一主题 下一主题

[参数配置] 请问下,MySQL单张表最大可以存多少行记录?

[复制链接]
跳转到指定楼层
1#
发表于 2014-3-7 12:12:29 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
请问下,Mysql单张表最大可以存多少行记录?一个Mysql数据库最大可以存多大的数据?40TB?
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友 微信微信
收藏收藏 分享淘帖 顶 踩
2#
发表于 2014-3-7 15:34:51 | 只看该作者
总之一句话: 手册里应该是这么介绍的,数据库数量是没有限制的,表的大小有限制,但一般受制于操作系统对文件大小的支持。

这个还分你用的是什么操作系统,不同的OS对文件大小的支持也不一样,用的是什么表引擎,不同的表类型大小限制也是不一样,。

而且其中表里的记录数,也跟记录大小有关,记录条小,存的数量多,记录条大,存的记录相应少...

一般般都不用考虑这么多,都是够用的。我遇到的系统单表有近200G的,单表记录有5亿条以上的,而已并发还很多,照样运行的很好。
3#
发表于 2014-3-7 15:39:06 | 只看该作者
这是MySQL5.6手册中的描述,可以细读下章节“E.10. Limits in MySQL”
E.10. Limits in MySQL
This section lists current limits in MySQL 5.6.
E.10.1. Limits of Joins
The maximum number of tables that can be referenced in a single join is 61. This also applies to the
number of tables that can be referenced in the definition of a view.
E.10.2. Limits on Number of Databases and Tables
MySQL has no limit on the number of databases. The underlying file system may have a limit on the
number of directories.
MySQL has no limit on the number of tables. The underlying file system may have a limit on the number
of files that represent tables. Individual storage engines may impose engine-specific constraints. InnoDB
permits up to 4 billion tables.
E.10.3. Limits on Table Size
The effective maximum table size for MySQL databases is usually determined by operating system
constraints on file sizes, not by MySQL internal limits.

4#
发表于 2014-3-7 15:45:41 | 只看该作者
这篇帖子写的挺好,摘抄过来,归纳总结,以作参考:
http://blog.csdn.net/oraclej/article/details/7745941


多少个数据库,是没有限制的,但是数据表的大小是有限制的.(前提是,这以前都要满足硬件的要求,文件的大小当然也不能超过操作系统支持的文件最大尺寸.


  • 对于ISAM数据表,单个.ISD和.ISM文件的最大尺寸都是4GB。
  • 对于MyISAM数据表,单个.MYD和.MYI默认也是4GB,但是可以在创建数据表的时候,利用AVG_ROW_LENGTH和MAX_ROWS选项把这个最大值扩大到800万TB。
  • MERGE数据表的尺寸是它的组成MyISAM数据表的最大尺寸之和。
  • BDB,随数据表页面尺寸变化,最小的页面尺寸(512byte),.db文件可以到2TB。
  • InnoDB数据表,最大尺寸是40亿个页面,默认的页面尺寸是16KB 。


强调,怎么也不能超过操作系统对一个文件的最到限制

max_rows主要对myisam生效,avg_row_length对blob,text字段起作用,以优化存储空间。
max_rows 是配合myisam_data_pointer_size使用的。


官方文档:
To change the default size limit for MyISAM tables, set the myisam_data_pointer_size, which sets the number of bytes
used for internal row pointers. The value is used to set the pointer size for new tables if you do not specify the MAX_ROWS op-
tion. The value of myisam_data_pointer_size can be from 2 to 7. A value of 4 permits tables up to 4GB; a value of 6
permits tables up to 256TB
如果你把max_rows 设为5, 但 myisam_data_pointer_size范围是 2~7, 2个字节就足够了( 2^16=64k),  所以其实就是让myisam是用2个字节的指针,并不是说最多5行。 如果你把max_rows 设为 100k,此时 100K>64K, 就要用3个字节表示,所以myisam_data_pointer_size会设为3, 此时最多存放 2^24行。

  1. mysql> create table t1 (a int) max_rows=2 engine=myisam;
  2. Query OK, 0 rows affected (0.05 sec)

  3. mysql> insert into t1 values(1);
  4. Query OK, 1 row affected (0.00 sec)

  5. mysql> insert into t1 values(1);
  6. Query OK, 1 row affected (0.00 sec)

  7. mysql> insert into t1 values(1);
  8. Query OK, 1 row affected (0.00 sec)

  9. mysql> insert into t1 values(1);
  10. Query OK, 1 row affected (0.00 sec)

  11. mysql> insert into t1 select * from t1;
  12. Query OK, 4 rows affected (0.01 sec)
  13. Records: 4  Duplicates: 0  Warnings: 0

  14. mysql> insert into t1 select * from t1;
  15. Query OK, 8 rows affected (0.00 sec)
  16. Records: 8  Duplicates: 0  Warnings: 0

  17. ............
  18. 继续执行insert into t1 select * from t1;
  19. ............
  20. mysql> select count(*) from t1;
  21. +----------+
  22. | count(*) |
  23. +----------+
  24. |    65535 |
  25. +----------+
  26. 1 row in set (0.00 sec)

  27. mysql> insert into t1 select * from t1;
  28. ERROR 1114 (HY000): The table 't1' is full
  29. mysql>
复制代码


1.4.4. MySQL表最大能达到多少
MySQL 3.22限制的表大小为4GB。由于在MySQL 3.23中使用了MyISAM存储引擎,最大表尺寸增加到了65536TB(2567 – 1字节)。由于允许的表尺寸更大,MySQL数据库的最大有效表尺寸通常是由操作系统对文件大小的限制决定的,而不是由MySQL内部限制决定的。

InnoDB存储引擎将InnoDB表保存在一个表空间内,该表空间可由数个文件创建。这样,表的大小就能超过单独文件的最大容量。表空间可包括原始磁盘分区,从而使得很大的表成为可能。表空间的最大容量为64TB。

在下面的表格中,列出了一些关于操作系统文件大小限制的示例。这仅是初步指南,并不是最终的。要想了解最新信息,请参阅关于操作系统的文档。

操作系统
文件大小限制
操作系统
文件大小限制
Linux 2.2-Intel 32-bit
2GB (LFS: 4GB)
Linux 2.4+
(using ext3 filesystem) 4TB
Solaris 9/10
16TB
NetWare w/NSS filesystem
8TB
win32 w/ FAT/FAT32
2GB/4GB
win32 w/ NTFS
2TB(可能更大)
MacOS X w/ HFS+
2TB

在Linux 2.2平台下,通过使用对ext2文件系统的大文件支持(LFS)补丁,可以获得超过2GB的MyISAM表。在Linux 2.4平台下,存在针对ReiserFS的补丁,可支持大文件(高达2TB)。目前发布的大多数Linux版本均基于2.4内核,包含所有所需的LFS补丁。使用JFS和XFS,petabyte(千兆兆)和更大的文件也能在Linux上实现。然而,最大可用的文件容量仍取决于多项因素,其中之一就是用于存储MySQL表的文件系统。

关于Linux中LFS的详细介绍,请参见Andreas Jaeger的“Linux中的大文件支持”页面:http://www.suse.de/~aj/linux_lfs.html

Windows用户请注意: FAT和VFAT (FAT32)不适合MySQL的生产使用。应使用NTFS。

在默认情况下,MySQL创建的MyISAM表允许的最大尺寸为4GB。你可以使用SHOW TABLE STATUS语句或myisamchk -dv tbl_name检查表的最大尺寸。请参见13.5.4节,“SHOW语法”。

如果需要使用大于4GB的MyISAM表(而且你的操作系统支持大文件),可使用允许AVG_ROW_LENGTH和MAX_ROWS选项的CREATE TABLE语句。请参见13.1.5节,“CREATE TABLE语法”。创建了表后,也可以使用ALTER TABLE更改这些选项,以增加表的最大允许容量。请参见13.1.2节,“ALTER TABLE语法”。

处理MyISAM表文件大小的其他方式:

  • 如果你的大表是只读的,可使用myisampack压缩它。myisampack通常能将表压缩至少50%,因而,从结果上看,可获得更大的表。此外,myisampack还能将多个表合并为1个表。请参见8.2节,“myisampack:生成压缩、只读MyISAM表”。
  • MySQL包含一个允许处理MyISAM表集合的MERGE库,这类MyISAM表具有与单个MERGE表相同的结构。请参见15.3节,“MERGE存储引擎”。


1.4.2. MySQL的的主要特性

......

可伸缩性和限制

处理大型数据库: 我们使用了MySQL服务器和含5千万条记录的数据库。我们还听说,有些用户将MySQL用于含60000个表和约50亿行的数据库。

每个表可支持高达64条索引(在MySQL 4.1.2之前为32条)。每条索引可由1~16个列或列元素组成。最大索引宽度为1000字节(在MySQL 4.1.2之前为500)。索引可使用具备CHAR、VARCHAR、BLOB或TEXT列类型的列前缀。
nycle2012 该用户已被删除
5#
发表于 2014-3-7 15:56:18 | 只看该作者
提示: 作者被禁止或删除 内容自动屏蔽
6#
 楼主| 发表于 2014-3-7 16:30:44 | 只看该作者
kider 发表于 2014-3-7 15:45
这篇帖子写的挺好,摘抄过来,归纳总结,以作参考:
http://blog.csdn.net/oraclej/article/details/77459 ...

相当牛逼啊!
8#
发表于 2014-4-3 13:25:59 | 只看该作者
{:soso_e179:}   霸气
9#
发表于 2014-6-16 22:30:52 | 只看该作者
参考如下链接
http://dev.mysql.com/doc/refman/5.5/en/table-size-limit.html
您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|申请友链|小黑屋|Archiver|手机版|MySQL社区 ( 京ICP备07012489号   
联系人:周生; 联系电话:13911732319

GMT+8, 2024-4-25 16:54 , Processed in 0.069447 second(s), 22 queries , Gzip On.

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表