MySQL基礎教程1 —— 數(shù)據(jù)類型之數(shù)值類型
MySQL支持所有標準SQL數(shù)值數(shù)據(jù)類型。這些類型包括嚴格數(shù)值數(shù)據(jù)類型(INTEGER、SMALLINT、DECIMAL和NUMERIC),以及近似數(shù)值數(shù)據(jù)類型(FLOAT、REAL和DOUBLE PRECISION)。關鍵字INT是INTEGER的同義詞,關鍵字DEC是DECIMAL的同義詞。
BIT數(shù)據(jù)類型保存位字段值,并且支持MyISAM、MEMORY、InnoDB和BDB表。
作為SQL標準的擴展,MySQL也支持整數(shù)類型TINYINT、MEDIUMINT和BIGINT。下面的表顯示了需要的每個整數(shù)類型的存儲和范圍。
類型字節(jié)最小值最大值 (帶符號的/無符號的)(帶符號的/無符號的)TINYINT1-128127 0255SMALLINT2-3276832767 065535MEDIUMINT3-83886088388607 016777215INT4-21474836482147483647 04294967295BIGINT8-92233720368547758089223372036854775807 018446744073709551615MySQL還支持選擇在該類型關鍵字后面的括號內(nèi)指定整數(shù)值的顯示寬度(例如,INT(4))。該可選顯示寬度規(guī)定用于顯示寬度小于指定的列寬度的值時從左側(cè)填滿寬度。
顯示寬度并不限制可以在列內(nèi)保存的值的范圍,也不限制超過列的指定寬度的值的顯示。
當結合可選擴展屬性ZEROFILL使用時, 默認補充的空格用零代替。例如,對于聲明為INT(5) ZEROFILL的列,值4檢索為00004。請注意如果在整數(shù)列保存超過顯示寬度的一個值,當MySQL為復雜聯(lián)接生成臨時表時會遇到問題,因為在這些情況下MySQL相信數(shù)據(jù)適合原列寬度。
所有整數(shù)類型可以有一個可選(非標準)屬性UNSIGNED。當你想要在列內(nèi)只允許非負數(shù)和該列需要較大的上限數(shù)值范圍時可以使用無符號值。
浮點和定點類型也可以為UNSIGNED。同數(shù)類型,該屬性防止負值保存到列中。然而,與整數(shù)類型不同的是,列值的上范圍保持不變。
如果為一個數(shù)值列指定ZEROFILL,MySQL自動為該列添加UNSIGNED屬性。
對于浮點列類型,在MySQL中單精度值使用4個字節(jié),雙精度值使用8個字節(jié)。
FLOAT類型用于表示近似數(shù)值數(shù)據(jù)類型。SQL標準允許在關鍵字FLOAT后面的括號內(nèi)選擇用位指定精度(但不能為指數(shù)范圍)。MySQL還支持可選的只用于確定存儲大小的精度規(guī)定。0到23的精度對應FLOAT列的4字節(jié)單精度。24到53的精度對應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,近似結果是999.0001。
MySQL將DOUBLE視為DOUBLE PRECISION(非標準擴展)的同義詞。MySQL還將REAL視為DOUBLE PRECISION(非標準擴展)的同義詞,除非SQL服務器模式包括REAL_AS_FLOAT選項。
為了保證最大可能的可移植性,需要使用近似數(shù)值數(shù)據(jù)值存儲的代碼應使用FLOAT或DOUBLE PRECISION,不規(guī)定精度或位數(shù)。
DECIMAL和NUMERIC類型在MySQL中視為相同的類型。它們用于保存必須為確切精度的值,例如貨幣數(shù)據(jù)。當聲明該類型的列時,可以(并且通常要)指定精度和標度;例如:
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)有關,但一般結果均被截取到允許的位數(shù))。
BIT數(shù)據(jù)類型可用來保存位字段值。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’相同。
當要在一個數(shù)值列內(nèi)保存一個超出該列允許范圍的值時,MySQL的操作取決于此時有效的SQL模式。如果模式未設置,MySQL將值裁剪到范圍的相應端點,并保存裁減好的值。但是,如果模式設置為traditional(“嚴格模式”),超出范圍的值將被拒絕并提示錯誤,并且根據(jù)SQL標準插入會失敗。
如果INT列是UNSIGNED,列范圍的大小相同,但其端點會變?yōu)榈?和4294967295。如果你試圖保存-9999999999和9999999999,以非嚴格模式保存到列中的值是0和4294967296。
如果在浮點或定點列中分配的值超過指定(或默認)精度和標度規(guī)定的范圍,MySQL以非嚴格模式保存表示范圍相應端點的值。
當MySQL沒有工作在嚴格模式時,對于ALTER TABLE、LOAD DATA INFILE、UPDATE和多行INSERT語句,由于裁剪發(fā)生的轉(zhuǎn)換將報告為警告。當MySQL工作在嚴格模式時,這些語句將失敗,并且部分或全部值不會插入或更改,取決于是否表為事務表和其它因素。
相關文章:
1. Access中批量替換數(shù)據(jù)庫內(nèi)容的兩種方法2. DB2 變更管理工具與Rational DA集成(1)3. 在Redhat Enterprise server 3上安裝oracle9iR2的注意事項4. SQL Server 2005使用基于行版本控制的隔離級別初探(3) -- SNAPSHOT5. 兩個sql server 2000的通用分頁存儲過程6. Microsoft Office Access添加網(wǎng)格線的方法7. oracle觸發(fā)器介紹8. Access數(shù)據(jù)庫安全的幾個問題9. MySQL中 concat函數(shù)的使用10. Delphi中的Access技巧集
