MySQL表最大能达到多少?
来源:互联网 发布:java的变量使用范围 编辑:程序博客网 时间:2024/06/03 02:17
InnoDB存储引擎将InnoDB表保存在一个表空间内,该表空间可由数个文件创建。这样,表的大小就能超过单独文件的最大容量。表空间可包括原始磁盘分区,从而使得很大的表成为可能。表空间的最大容量为64TB。
在下面的表格中,列出了一些关于操作系统文件大小限制的示例。这仅是初步指南,并不是最终的。要想了解最新信息,请参阅关于操作系统的文档。
操作系统
文件大小限制
Linux 2.2-Intel 32-bit
2GB (LFS: 4GB)
Linux 2.4+
(使用 ext3 文件系统) 4TB
Solaris 9/10
16TB
NetWare w/NSS 文件系统
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 -dvtbl_name检查表的最大尺寸。
1
mysql > show table status like 't_user';
如果需要使用大于4GB的MyISAM表(而且你的操作系统支持大文件),可使用允许AVG_ROW_LENGTH和MAX_ROWS选项的CREATE TABLE语句。
创建了表后,也可以使用ALTER TABLE更改这些选项,以增加表的最大允许容量。
以下语句将表的最大容量设成了1000G(1TB)
1
mysql > alter table t_user max_rows = 200000000000 avg_row_length = 50;
处理MyISAM表文件大小的其他方式:
如果你的大表是只读的,可使用myisampack压缩它。myisampack通常能将表压缩至少50%,因而,从结果上看,可获得更大的表。此外,myisampack还能将多个表合并为1个表。
MySQL包含一个允许处理MyISAM表集合的MERGE库,这类MyISAM表具有与单个MERGE表相同的结构。
下面是一个例子:
这是一个存储天气的表:
mysql> describe weather; +-----------+--------------+------+-----+------------+-------+ | Field | Type | Null | Key | Default | Extra | +-----------+--------------+------+-----+------------+-------+ | city | varchar(100) | | MUL | | | | high_temp | tinyint(4) | | | 0 | | | low_temp | tinyint(4) | | | 0 | | | the_date | date | | | 0000-00-00 | | +-----------+--------------+------+-----+------------+-------+ 4 rows in set (0.01 sec)
看看它的容量大小限制,我们使用 SHOW TABLE STATUS
mysql> show table status like 'weather' \G *************************** 1. row *************************** Name: weather Type: MyISAM Row_format: Dynamic Rows: 0 Avg_row_length: 0 Data_length: 0 Max_data_length: 4294967295 Index_length: 1024 Data_free: 0 Auto_increment: NULL Create_time: 2003-03-03 00:43:43 Update_time: 2003-03-03 00:43:43 Check_time: 2003-06-14 15:11:21 Create_options: Comment: 1 row in set (0.00 sec)
注意 Max_data_length 为4GB. 我们把它改大:
mysql> alter table weather max_rows = 200000000000 avg_row_length = 50; Query OK, 0 rows affected (0.03 sec) Records: 0 Duplicates: 0 Warnings: 0 mysql> show table status like 'weather' \G *************************** 1. row *************************** Name: weather Type: MyISAM Row_format: Dynamic Rows: 0 Avg_row_length: 0 Data_length: 0 Max_data_length: 1099511627775 Index_length: 1024 Data_free: 0 Auto_increment: NULL Create_time: 2003-06-17 13:12:49 Update_time: 2003-06-17 13:12:49 Check_time: NULL Create_options: max_rows=4294967295 avg_row_length=50 Comment: 1 row in set (0.00 sec)
现在的表可以存储更多的内容了.
是否行数太多?
修改容量后,你会发现(上面例子)Create_options 中多了最大行数的限制4294967295,是的,它仍然有一定的限制,但现在的限制是行数,并不是表的容量大小了。也就是说你的最大行数不能超过4294967295.
为什么?
因为系统是32位,如果你移到64位的系统里,这个行数限制就会增加.
- MySQL表最大能达到多少
- MySQL表最大能达到多少?
- 1.4.4. MySQL表最大能达到多少
- 4G内存服务器epoll并发量最大能达到多少
- 数组最大能开导多少
- 一年外包工作经验深圳辞职后工资水平能达到多少?
- session中最大能放多少数据?
- 求树中每个点能达到的最大距离
- MySQL一张表最多能存多少条记录?
- MySQL最多能装多少记录
- mysql varchar到底能存多少汉字?
- GET与POST传递数据的最大长度能够达到多少
- GET与POST传递数据的最大长度能够达到多少
- Edit框最大能输入多少个字符
- TCP服务器最大能支持多少长连接
- 【C语言】检测malloc最大能分配多少空间。
- STM32局部变量的数组最大能到多少?
- mysql 列出符合记录里面某个条件达到多少个数量的用户
- Flex + java + orcale 存取Image
- 寒假-05,贪吃蛇
- STL list链表的用法详解
- Hello CSDN
- MFC POST 文件到 http服务器
- MySQL表最大能达到多少?
- Android面试题之二(中)
- C#.net访问web URL并处理返回值 && 不加web引用调用webservice
- .NET 强制退出WinForm程序 C#+.NET
- winform最小化后隐藏到右下角,单击或双击后恢复
- 我的第一个C++程序
- 如何用C#语言构造蜘蛛程序
- [python] os.walk()与os.path.walk()
- 十大Visual Studio插件