1. 程式人生 > >MYSQL數值型別INT,SMALLINT,BIGINT,MEDIUMINT,FLOAT的相關說明,儲存大小等!

MYSQL數值型別INT,SMALLINT,BIGINT,MEDIUMINT,FLOAT的相關說明,儲存大小等!

MySQL支援所有標準SQL數值資料型別。這些型別包括嚴格數值資料型別(INTEGERSMALLINTDECIMALNUMERIC),以及近似數值資料型別(FLOATREALDOUBLEPRECISION)。關鍵字INTINTEGER的同義詞,關鍵字DECDECIMAL的同義詞。

BIT資料型別儲存位欄位值,並且支援MyISAMMEMORYInnoDBBDB表。

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

型別

位元組

最小值

最大值

(帶符號的/無符號的)

(帶符號的/無符號的)

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還支援選擇在該型別關鍵字後面的括號內指定整數值的顯示寬度(

例如,INT(4))。該可選顯示寬度規定用於顯示寬度小於指定的列寬度的值時從左側填滿寬度。

顯示寬度並不限制可以在列內儲存的值的範圍,也不限制超過列的指定寬度的值的顯示。

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

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

浮點和定點型別也可以為UNSIGNED

。同數型別,該屬性防止負值儲存到列中。然而,與整數型別不同的是,列值的上範圍保持不變。

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

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

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

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

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

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

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

salary DECIMAL(5,2)

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

MySQL5.1中以二進位制格式儲存DECIMALNUMERIC值。

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

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

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

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

要指定位值,可以使用b'value'符。value是一個用01編寫的二進位制值。例如,b'111'b'100000000'分別表示7128。參見9.1.5節,“位欄位值”

如果為BIT(M)列分配的值的長度小於M位,在值的左邊用0填充。例如,為BIT(6)列分配一個值b'101',其效果與分配b'000101'相同。

當要在一個數值列內儲存一個超出該列允許範圍的值時,MySQL的操作取決於此時有效的SQL模式。如果模式未設定,MySQL將值裁剪到範圍的相應端點,並儲存裁減好的值。但是,如果模式設定為traditional(“嚴格模式),超出範圍的值將被拒絕並提示錯誤,並且根據SQL標準插入會失敗。參見5.3.2節,“SQL伺服器模式”

如果INT列是UNSIGNED,列範圍的大小相同,但其端點會變為到04294967295。如果你試圖儲存-99999999999999999999,以非嚴格模式儲存到列中的值是04294967296

如果在浮點或定點列中分配的值超過指定(或預設)精度和標度規定的範圍,MySQL以非嚴格模式儲存表示範圍相應端點的值。

MySQL沒有工作在嚴格模式時,對於ALTERTABLELOAD DATAINFILEUPDATE和多行INSERT語句,由於裁剪髮生的轉換將報告為警告。當MySQL工作在嚴格模式時,這些語句將失敗,並且部分或全部值不會插入或更改,取決於是否表為事務表和其它因素。詳情參見5.3.2節,“SQL伺服器模式”