如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 |