Mysql中 int(10)和int(11)的區別

pythontab發表於2016-07-23

int(M) M指示最大顯示寬度。最大有效顯示寬度是255。顯示寬度與儲存大小或型別包含的值的範圍無關

首先說一下MySQL的數值型別,MySQL支援所有標準SQL數值資料型別。這些型別包括嚴格數值資料型別(INTEGER、SMALLINT、DECIMAL和NUMERIC),以及近似數值資料型別(FLOAT、REAL和DOUBLE PRECISION)。關鍵字INT是INTEGER的同義詞,關鍵字DEC是DECIMAL的同義詞。


BIT資料型別儲存位欄位值,並且支援MyISAM、MEMORY、InnoDB和BDB表。


作為SQL標準的擴充套件,MySQL也支援整數型別TINYINT、MEDIUMINT和BIGINT。下面的表顯示了需要的每個整數型別的儲存和範圍。

型別位元組最小值最大值(帶符號的)
TINYINT1-128 127
SMALLINT2-3276832767
MEDIUMINT3-83886088388607
INT4-21474836482147483647
BIGINT8-92233720368547758089223372036854775807


Mysql型別關鍵字後面的括號內指定整數值的顯示寬度(例如,INT(4))。該可選顯示寬度規定用於顯示寬度小於指定的列寬度的值時從左側填滿寬度。顯示寬度並不限制可以在列內儲存的值的範圍,也不限制超過列的指定寬度的值的顯示。


當結合可選擴充套件屬性ZEROFILL使用時, 預設補充的空格用零代替。例如,對於宣告為INT(5) ZEROFILL的列,值4檢索為00004。請注意如果在整數列儲存超過顯示寬度的一個值,當MySQL為複雜聯接生成臨時表時會遇到問題,因為在這些情況下MySQL相信資料適合原列寬度。


所有整數型別可以有一個可選(非標準)屬性UNSIGNED。當你想要在列內只允許非負數和該列需要較大的上限數值範圍時可以使用無符號值。


所以int(10)與int(11)後的括號中的字元表示顯示寬度,整數列的顯示寬度與mysql需要用多少個字元來顯示該列數值,與該整數需要的儲存空間的大小都沒有關係,int型別的欄位能儲存的資料上限還是2147483647(有符號型)和4294967295(無符號型)。



浮點和定點型別也可以為UNSIGNED。同數型別,該屬性防止負值儲存到列中。然而,與整數型別不同的是,列值的上範圍保持不變。


如果為一個數值列指定ZEROFILL,MySQL自動為該列新增UNSIGNED屬性。


對於浮點列型別,在MySQL中單精度值使用4個位元組,雙精度值使用8個位元組。


FLOAT型別用於表示近似數值資料型別。SQL標準允許在關鍵字FLOAT後面的括號內選擇用位指定精度(但不能為指數範圍)。MySQL還支援可選的只用於確定儲存大小的精度規定。0到23的精度對應FLOAT列的4位元組單精度。24到53的精度對應DOUBLE列的8位元組雙精度。


MySQL允許使用非標準語法:FLOAT(M,D)或REAL(M,D)或DOUBLE PRECISION(M,D)。這裡,“(M,D)”表示該值一共顯示M位整數,其中D位位於小數點後面。例如,定義為FLOAT(7,4)的一個列可以顯示為-999.9999。MySQL儲存值時進行四捨五入,因此如果在FLOAT(7,4)列內插入999.00009,近似結果是999.0001。


MySQL將DOUBLE視為DOUBLE PRECISION(非標準擴充套件)的同義詞。MySQL還將REAL視為DOUBLE PRECISION(非標準擴充套件)的同義詞,除非SQL伺服器模式包括REAL_AS_FLOAT選項。


為了保證最大可能的可移植性,需要使用近似數值資料值儲存的程式碼應使用FLOAT或DOUBLE PRECISION,不規定精度或位數。


DECIMAL和NUMERIC型別在MySQL中視為相同的型別。它們用於儲存必須為確切精度的值,例如貨幣資料。當宣告該型別的列時,可以(並且通常要)指定精度和標度;例如:


salary DECIMAL(5,2)

在該例子中,5是精度,2是標度。精度表示儲存值的主要位數,標度表示小數點後面可以儲存的位數。


在MySQL 5.1中以二進位制格式儲存DECIMAL和NUMERIC值。


標準SQL要求salary列能夠用5位整數位和兩位小數儲存任何值。因此,在這種情況下可以儲存在salary列的值的範圍是從-999.99到999.99。


在標準SQL中,語法DECIMAL(M)等價於DECIMAL(M,0)。同樣,語法DECIMAL等價於DECIMAL(M,0),可以透過計算確定M的值。在MySQL 5.1中支援DECIMAL和NUMERIC資料型別的變數形式。M預設值是10。


DECIMAL或NUMERIC的最大位數是65,但具體的DECIMAL或NUMERIC列的實際範圍受具體列的精度或標度約束。如果此類列分配的值小數點後面的位數超過指定的標度允許的範圍,值被轉換為該標度。(具體操作與作業系統有關,但一般結果均被擷取到允許的位數)。


BIT資料型別可用來儲存位欄位值。BIT(M)型別允許儲存M位值。M範圍為1到64。


要指定位值,可以使用b’value’符。value是一個用0和1編寫的二進位制值。例如,b’111′和b’100000000′分別表示7和128。


相關文章