mysql bigint(20)中的20到底代表的是什么?


如mysql介紹文檔所知,mysql的數據類型及具體的存儲長處如下表所示

數據類型 存儲長度
TINYINT -128 - 127 
TINYINT UNSIGNED  0 - 255
SMALLINT -32768 - 32767 
SMALLINT UNSIGNED  0 - 65535 
MEDIUMINT -8388608 - 8388607 

MEDIUMINT UNSIGNED 

0 - 16777215 
INT 或 INTEGER  -2147483648 - 2147483647 
INT UNSIGNED 或 INTEGER UNSIGNED  0 - 4294967295
BIGINT  -9223372036854775808 - 9223372036854775807 
BIGINT UNSIGNED  0 - 18446744073709551615
FLOAT  -3.402823466E+38 - -1.175494351E-38,0,1.175494351E-38 - 3.402823466E+38 
DOUBLE 或 DOUBLE PRECISION 或 REAL  1.7976931348623157E+308 - -2.2250738585072014E-308,0,2.2250738585072014E-308 - 1.7976931348623157E+308 
DECIMAL[(M,[D])] 或 NUMERIC(M,D) 由M(整個數字的長度,包括小數點,小數點左邊的位數,小數點右邊的位數,但不包括負號)和D(小數點右邊的位數)來決定,M缺省為10,D缺省為0 
DATE  1000-01-01 - 9999-12-31
DATETIME 1000-01-01 00:00:00 - 9999-12-31 23:59:59
TIMESTAMP 1970-01-01 00:00:00 - 203年的某一天
TIME -838:59:59' to 838:59:59 
YEAR[(2|4)]  缺省為4位格式,4位格式取值范圍為1901 - 2155,0000,2位格式取值范圍為70-69(1970-2069) 
CHAR(M) [BINARY] 或 NCHAR(M) [BINARY]  M的范圍為1 - 255,如果沒有BINARY項,則不分大小寫,NCHAR表示使用缺省的字符集.在數據庫中以空格補足,但在取出來時末尾的空格將自動去掉. 
[NATIONAL] VARCHAR(M) [BINARY]  M的范圍為1 - 255.在數據庫中末尾的空格將自動去掉. 
TINYBLOB 或 TINYTEXT  255(2^8-1)個字符
BLOB 或 TEXT  65535(2^16-1)個字符 
MEDIUMBLOB 或 MEDIUMTEXT 
16777215 (2^24-1)個字符 
LONGBLOB 或 LONGTEXT  4294967295 (2^32-1)個字符 
ENUM('value1','value2',...)  可以總共有65535個不同的值 
SET('value1','value2',...)  最多有64個成員 

在日常工作中,對於mysql定義語句經常寫的bigint(20)這個其中的20到底是什么含義,比較容易和數據類型真實存儲的數據大小混淆,下面介紹,這里的20到底是什么

括號里的數字叫數據的寬度,不同的數據類型對寬度的處理也不一樣:
1、整數類型,這里顯示的寬度和數據類型的取值范圍是沒有任何關系的,顯示寬度只是指明Mysql最大可能顯示的數字個數,數值的位數小於指定的寬度時會由空格填充;如果插入了大於顯示寬度的值,只要該值不超過該類型的取值范圍,數值依然可以插入,而且能夠顯示出來。例如上面的udi,顯示的寬度是4,但是我向uid中插入100001,也是可以的,保存和顯示的都會是100001;如果你不設置寬度,系統將添加默認的寬度tinyint(4),smallint(6),mediumint(9),int(11),bigint(20),這些默認的寬度是跟該類型的取值范圍長度相關。
2、字符串類型,字符串類型這個寬度才真的用上了。不管是char還是varchar,寬度都定義了字符串的最大長度;例如上面的 password varchar(20),如果你輸入了一個21個字符的密碼,那么保存和顯示的只會是前20個字符,你將丟失一個字符信息,char同理。由於varchar是變長存儲的,所以實際開發中我們一般都把varchar的寬度設為最長255,反正你沒用完它也不會浪費空間。
3、浮點和日期等數據類型對數據的寬度沒有要求,一般也不設置,默認是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  


免責聲明!

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



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