MySQL_bigint(20) 是什么意思? int默認顯示寬度


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


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM