MySQL支持全部標準SQL數值數據類型。這些類型包括嚴格數值數據類型(INTEGER、SMALLINT、DECIMAL和NUMERIC),以及近似數值數據類型(FLOAT、REAL和DOUBLE PRECISION)。關鍵字INT是INTEGER的同義詞,關鍵字DEC是DECIMAL的同義詞。html
BIT數據類型保存位字段值,而且支持MyISAM、MEMORY、InnoDB和BDB表。mysql
做爲SQL標準的擴展,MySQL也支持整數類型TINYINT、MEDIUMINT和BIGINT。下面的表顯示了須要的每一個整數類型的存儲和範圍。sql
類型服務器 |
字節ide |
最小值post |
最大值spa |
|
|
(帶符號的/無符號的)操作系統 |
(帶符號的/無符號的)server |
TINYINThtm |
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還支持選擇在該類型關鍵字後面的括號內指定整數值的顯示寬度(例如,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。參見9.1.5節,「位字段值」。
若是爲BIT(M)列分配的值的長度小於M位,在值的左邊用0填充。例如,爲BIT(6)列分配一個值b'101',其效果與分配b'000101'相同。
當要在一個數值列內保存一個超出該列容許範圍的值時,MySQL的操做取決於此時有效的SQL模式。若是模式未設置,MySQL將值裁剪到範圍的相應端點,並保存裁減好的值。可是,若是模式設置爲traditional(「嚴格模式」),超出範圍的值將被拒絕並提示錯誤,而且根據SQL標準插入會失敗。參見5.3.2節,「SQL服務器模式」。
若是INT列是UNSIGNED,列範圍的大小相同,但其端點會變爲到0和4294967295。若是你試圖保存-9999999999和9999999999,以非嚴格模式保存到列中的值是0和4294967296。
若是在浮點或定點列中分配的值超過指定(或默認)精度和標度規定的範圍,MySQL以非嚴格模式保存表示範圍相應端點的值。
當MySQL沒有工做在嚴格模式時,對於ALTER TABLE、LOAD DATA INFILE、UPDATE和多行INSERT語句,因爲裁剪髮生的轉換將報告爲警告。當MySQL工做在嚴格模式時,這些語句將失敗,而且部分或所有值不會插入或更改,取決因而否表爲事務表和其它因素。詳情參見5.3.2節,「SQL服務器模式」。