MySQL支援所有標準SQL數值資料型態。這些型別包括嚴格數值資料型別(INTEGER、SMALLINT、DECIMAL和NUMERIC),以及近似數值資料型別(FLOAT、REAL和DOUBLE PRECISION)。關鍵字INT是INTEGER的同義詞,關鍵字DEC是DECIMAL的同義詞。
BIT資料類型保存位元欄位值,並且支援MyISAM、MEMORY、InnoDB和BDB表。
作為SQL標準的擴展,MySQL也支援整數型TINYINT、MEDIUMINT和BIGINT。下面的表格顯示了需要的每個整數類型的儲存和範圍。
類型 位元組 最小值 最大值
(帶符號的/無符號的) (帶符號的/無符號的)
TIINTINT 0 255 SMALLINT 2 -32768 32767 0 65535 MEDIUMINT 3 -8388608 8388607 0 167777215 0 167777215 648 2147483647 0 4294967295 BIGINT 8 -92237203683875368 7 0 18446744073709551615 MySQL也支援選擇在該類型關鍵字後面的括號內指定整數值的顯示寬度(例如,INT(4))。此選用顯示寬度規定用於顯示寬度小於指定的列寬度的值時從左側填滿寬度。 顯示寬度並不限制可以在列內保存的值的範圍,也不限制超過列的指定寬度的值的顯示。 當結合可選擴展屬性ZEROFILL使用時, 預設補充的空格用零代替。例如,對於宣告為INT(5) ZEROFILL的資料列,值4檢索為00004。請注意如果在整數列中保存超過顯示寬度的一個值,當MySQL為複雜聯結產生臨時表時會遇到問題,因為在這些情況下MySQL相信資料適合原列寬度。 所有整數類型可以有一個可選(非標準)屬性UNSIGNED。當你想要在列內只允許非負數和該列需要較大的上限數值範圍時可以使用無符號值。 浮點和定點類型也可以為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。
如果BIT(M)列分配的值的長度小於M位,在值的左邊用0填充。例如,為BIT(6)欄位指派一個值b'101',其效果與分配b'000101'相同。
當要在一個數值列內保存一個超出該列允許範圍的值時,MySQL的操作取決於此時有效的SQL模式。如果模式未設置,MySQL將值裁切到範圍的對應端點,並儲存裁減好的值。但是,如果模式設定為traditional(“嚴格模式”),超出範圍的值將被拒絕並提示錯誤,並且根據SQL標準插入會失敗。
如果INT欄位是UNSIGNED,則列範圍的大小相同,但其端點會變成0和4294967295。如果你試圖保存-9999999999和9999999999,以非嚴格模式保存到列中的值是0和4294967296。
如果在浮點或定點列中分配的值超過指定(或預設)精度和標度規定的範圍,MySQL以非嚴格模式保存表示範圍相應端點的值。
當MySQL沒有工作在嚴格模式時,對於ALTER TABLE、LOAD DATA INFILE、UPDATE和多行INSERT語句,由於裁剪發生的轉換將報告為警告。當MySQL工作在嚴格模式時,這些語句將會失敗,且部分或全部值不會插入或更改,取決於是否表為事務表和其它因素。