int(M) M指示最大顯示寬度患民。最大有效顯示寬度是255御蒲。顯示寬度與存儲大小或類型包含的值的范圍無關(guān)
- 首先說一下mysql的數(shù)值類型衣赶,mysql支持所有標準SQL數(shù)值數(shù)據(jù)類型。這些類型包括嚴格數(shù)值數(shù)據(jù)類型(INTEGER厚满、SMALLINT府瞄、DECIMAL和NUMERIC),以及近似數(shù)值數(shù)據(jù)類型(FLOAT碘箍、REAL和DOUBLE PRECISION)遵馆。關(guān)鍵字INT是INTEGER的同義詞鲸郊,關(guān)鍵字DEC是DECIMAL的同義詞。
- BIT數(shù)據(jù)類型保存位字段值货邓,并且支持MyISAM秆撮、MEMORY、InnoDB和BDB表换况。
- 作為SQL標準的擴展职辨,MySQL也支持整數(shù)類型TINYINT、MEDIUMINT和BIGINT戈二。下面的表顯示了需要的每個整數(shù)類型的存儲和范圍拨匆。
| 類型 | 字節(jié) | 最小值(帶符號的) | 最大值(帶符號 |最小值(無符號)|最大值(無符號)|
| ------------- |:-------------:| -----:|
|TINYINT | 1|-128 | 127|0|255|
| SMALLINT| 2|-32768|32767|0|65535|
| MEDIUMINT | 3|-8388608|8388607|0|16777215|
| INT | 4|-2147483648|2147483647|0|4294967295|
| BIGINT | 8|-9223372036854775808|9223372036854775807|0|18446744073709551615|
Mysql類型關(guān)鍵字后面的括號內(nèi)指定整數(shù)值的顯示寬度(例如,INT(4))挽拂。該可選顯示寬度規(guī)定用于顯示寬度小于指定的列寬度的值時從左側(cè)填滿寬度惭每。顯示寬度并不限制可以在列內(nèi)保存的值的范圍,也不限制超過列的指定寬度的值的顯示亏栈。
當(dāng)結(jié)合可選擴展屬性ZEROFILL使用時台腥, 默認補充的空格用零代替。例如绒北,對于聲明為INT(5) ZEROFILL的列黎侈,值4檢索為00004。請注意如果在整數(shù)列保存超過顯示寬度的一個值闷游,當(dāng)MySQL為復(fù)雜聯(lián)接生成臨時表時會遇到問題峻汉,因為在這些情況下MySQL相信數(shù)據(jù)適合原列寬度。
所有整數(shù)類型可以有一個可選(非標準)屬性UNSIGNED脐往。當(dāng)你想要在列內(nèi)只允許非負數(shù)和該列需要較大的上限數(shù)值范圍時可以使用無符號值休吠。所以int(10)與int(11)后的括號中的字符表示顯示寬度,整數(shù)列的顯示寬度與mysql需要用多少個字符來顯示該列數(shù)值业簿,與該整數(shù)需要的存儲空間的大小都沒有關(guān)系瘤礁,int類型的字段能存儲的數(shù)據(jù)上限還是2147483647(有符號型)和4294967295(無符號型)。
浮點和定點類型也可以為UNSIGNED梅尤。同數(shù)類型柜思,該屬性防止負值保存到列中。然而巷燥,與整數(shù)類型不同的是赡盘,列值的上范圍保持不變。如果為一個數(shù)值列指定ZEROFILL缰揪,MySQL自動為該列添加UNSIGNED屬性陨享。對于浮點列類型,在MySQL中單精度值使用4個字節(jié),雙精度值使用8個字節(jié)霉咨。
FLOAT類型用于表示近似數(shù)值數(shù)據(jù)類型。SQL標準允許在關(guān)鍵字FLOAT后面的括號內(nèi)選擇用位指定精度(但不能為指數(shù)范圍)拍屑。MySQL還支持可選的只用于確定存儲大小的精度規(guī)定途戒。0到23的精度對應(yīng)FLOAT列的4字節(jié)單精度。24到53的精度對應(yīng)DOUBLE列的8字節(jié)雙精度僵驰。
MySQL允許使用非標準語法:FLOAT(M,D)或REAL(M,D)或DOUBLE PRECISION(M,D)喷斋。這里,“(M,D)”表示該值一共顯示M位整數(shù)蒜茴,其中D位位于小數(shù)點后面星爪。例如,定義為FLOAT(7,4)的一個列可以顯示為-999.9999粉私。MySQL保存值時進行四舍五入顽腾,因此如果在FLOAT(7,4)列內(nèi)插入999.00009,近似結(jié)果是999.0001诺核。
MySQL將DOUBLE視為DOUBLE PRECISION(非標準擴展)的同義詞抄肖。MySQL還將REAL視為DOUBLE PRECISION(非標準擴展)的同義詞,除非SQL服務(wù)器模式包括REAL_AS_FLOAT選項窖杀。
為了保證最大可能的可移植性漓摩,需要使用近似數(shù)值數(shù)據(jù)值存儲的代碼應(yīng)使用FLOAT或DOUBLE PRECISION,不規(guī)定精度或位數(shù)入客。
DECIMAL和NUMERIC類型在MySQL中視為相同的類型管毙。它們用于保存必須為確切精度的值,例如貨幣數(shù)據(jù)桌硫。當(dāng)聲明該類型的列時夭咬,可以(并且通常要)指定精度和標度;例如:salary DECIMAL(5,2)在該例子中铆隘,5是精度皱埠,2是標度。精度表示保存值的主要位數(shù)咖驮,標度表示小數(shù)點后面可以保存的位數(shù)边器。在MySQL 5.1中以二進制格式保存DECIMAL和NUMERIC值。
標準SQL要求salary列能夠用5位整數(shù)位和兩位小數(shù)保存任何值托修。因此忘巧,在這種情況下可以保存在salary列的值的范圍是從-999.99到999.99。在標準SQL中睦刃,語法DECIMAL(M)等價于DECIMAL(M,0)砚嘴。同樣,語法DECIMAL等價于DECIMAL(M,0),可以通過計算確定M的值际长。在MySQL 5.1中支持DECIMAL和NUMERIC數(shù)據(jù)類型的變量形式耸采。M默認值是10。
DECIMAL或NUMERIC的最大位數(shù)是65工育,但具體的DECIMAL或NUMERIC列的實際范圍受具體列的精度或標度約束虾宇。如果此類列分配的值小數(shù)點后面的位數(shù)超過指定的標度允許的范圍,值被轉(zhuǎn)換為該標度如绸。(具體操作與操作系統(tǒng)有關(guān)嘱朽,但一般結(jié)果均被截取到允許的位數(shù))。
BIT數(shù)據(jù)類型可用來保存位字段值怔接。BIT(M)類型允許存儲M位值搪泳。M范圍為1到64。
要指定位值扼脐,可以使用b’value’符岸军。value是一個用0和1編寫的二進制值。例如瓦侮,b’111′和b’100000000′分別表示7和128凛膏。