MySQL的整型類型有這樣幾種:
類型 | 存儲空間 | M默認值(顯示寬度) | 數據大小(無符號:unsigned) | 描述 | |
1 | tinyint(M) | 1 | tinyint(4) | 有符號的范圍:-128 到 127,無符號的范圍: 0 到 255 的整型數據。 | 一個極小整數。 |
2 | smallint(M) | 2 | smallint(6) | 有符號的范圍:-2^15 (-32,768) 到 2^15-1 (32,767) 的整型數據,無符號的范圍:-32768 到 32767 【3萬左右】 |
一個小整數。 |
3 | mediumint(M) | 3 | mediumint(9) | 有符號的范圍:-8388608到8388607,無符號的范圍:0到16777215的整型數據。【1600萬左右】 | 一個中等大小整數。 |
4 | int(M) |
4 | int(11) | -2^31 (-2,147,483,648) 到 2^31-1 (2,147,483,647) 的整型數據。【21億左右】 |
一個正常大小整數。 |
5 | bigint(M) | 8 | bigint(20) | -2^63 (-9223372036854775808) 到 2^63-1 (9223372036854775807) 的整型數據。【遠大於21億左右】 |
一個略大整數 |
數據大小排序 | bigint(M) > int(M) > mediumint(M) > smallint(M) > tinyint(M) |
存儲空間:存儲需要占用多少字節(占用字節 btyes)。
M:表示最大顯示寬度,建表若設置 zerofill (0填充),會在數字前面補充0。若沒有設置0填充,那么直接顯示,不會影響存儲空間大小,沒用上就沒用上,省下了。
舉例說明:
存儲數字 | 存儲空間 | 實際顯示寬度 | 實際顯示 | |
tinyint(3) | 33 | 1 | 3 | 033 |
tinyint(10) | 33 | 1 | 10 | 0000000033 |
bigint(10) | 666 | 8 | 10 | 0000000666 |
bigint(20) | 666 | 8 | 20 | 00000000000000000666 |
如果還不懂,可看下面解釋:
mysql bigint(20)中20指的是
:該字段下能輸出顯示的最大數字長度。
括號里的數字叫數據的寬度,不同的數據類型對寬度的處理也不一樣:
1、整數類型:
這里顯示的寬度和數據類型的取值范圍是沒有任何關系的,顯示寬度只是指明Mysql最大可能顯示的數字個數,數值的位數小於指定的寬度時會由空格填充;
如果插入了大於顯示寬度的值,只要該值不超過該類型的取值范圍,數值依然可以插入,而且能夠顯示出來。
如果你不設置寬度,系統將添加默認的寬度tinyint(4)、smallint(6)、mediumint(9)、int(11)、bigint(20),這些默認的寬度是跟該類型的取值范圍長度相關。
2、字符串類型:
字符串類型這個寬度才真的用上了。不管是char還是varchar,寬度都定義了字符串的最大長度;例如上面的 password varchar(20),如果你輸入了一個21個字符的密碼,那么保存和顯示的只會是前20個字符,你將丟失一個字符信息,char同理。由於varchar是變長存儲的,所以實際開發中我們一般都把varchar的寬度設為最長255,它會根據實際數據長度變化,反正你沒用完它也不會浪費空間。char是定長存儲,定義多長就是多長。
3、浮點和日期等數據類型:
對數據的寬度沒有要求,一般也不設置,默認是0。
參考文檔:
https://www.cnblogs.com/wulw829/p/11325285.html