MySQL的最大與最小

chenfeng發表於2017-05-10
1. 一個表裡最多可有1017列(在MySQL 5.6.9 之前最大支援1000列)。虛擬列也受限這個限制。
2. 一個表最多可以有64個二級索引。
3. 如果innodb_large_prefix開啟,在InnoDB表DYNAMIC或COMPRESSED列格式下,索引字首最大支援前3072位元組;如果不開啟的話,在任意列格式下,最多支援前767位元組。 這個限制既適用於字首索引也適用於全列索引。
4. 基於一個16KB的頁最多裝3072個位元組,如果你把InnoDB 的page 大小從8KB降到4KB,索引的長度也相應的降低。也就是說,當頁是8KB的時候最大索引長度是1536位元組;當頁大小是4KB的時候最大索引長度是768位元組;
5. 聯合索引最多支援16列,如果超過這個限制就會遇到以下錯誤:
ERROR 1070 (42000): Too many key parts specified; max 16 parts allowed
6. 行長度(除去可變長型別:VARBINARY/VARCHAR/BLOB/TEXT),要小於頁長(如4KB, 8KB, 16KB, and 32KB)的一半。
例如:innodb_page_size 長度是16KB的話,行長不超過8KB;如果innodb_page_size 是64KB的話,行長不超過16KB; LONGBLOB/LONGTEXT/BLOB/TEXT列必須小於4GB,整個行長也必須小於4GB。
如果一行小於一頁的一半,它可以存在一個page裡面。如果超過了頁的一半,就會把可變長列放到額外的頁存。

7. 雖然InnoDB內部支援行長大於65,535位元組,但是MySQL限制了所有列的組合長度。 例如:
mysql> CREATE TABLE t (a VARCHAR(8000), b VARCHAR(10000),   
-> c VARCHAR(10000), d VARCHAR(10000), e VARCHAR(10000),   
-> f VARCHAR(10000), g VARCHAR(10000)) ENGINE=InnoDB;
ERROR 1118 (42000): Row size too large. The maximum row size for the used table type, not counting BLOBs, is 65535. You have to change somecolumns to TEXT or BLOBs
8. 在一些老作業系統中,檔案必須小於2GB。這並非是InnoDB本身的限制,如果你需要大的表空間,就要配置使用幾個小的資料檔案而不是一個大的資料檔案。
9. InnoDB日誌檔案組合大小最大可以是512GB。
10. 最小的表空間是10MB,最大的表空間取決於InnoDB頁大小(最大表空間也就是最大表大小)

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/15498/viewspace-2138807/,如需轉載,請註明出處,否則將追究法律責任。

相關文章