MySQL中述职类型的长度问题
int(M) M指示最大顯示寬度。最大有效顯示寬度是255。顯示寬度與存儲大小或類型包含的值的范圍無關
?
在SQL語句中int代表你要創建字段的類型,int代表整型,11代表字段的長度。
這個11代表顯示寬度,整數列的顯示寬度與mysql需要用多少個字符來顯示該列數值,與該整數需要的存儲空間的大小都沒有關系,比如,不管設定了顯示寬度是多少個字符,bigint都要占用8個字節。
int是整型,(11)是指顯示字符的長度,但要加參數的,最大為255,比如它是記錄行數的id,插入10筆資料,它就顯示00000000001 ~~~00000000010,當字符的位數超過11,它也只顯示11位,如果你沒有加那個讓它未滿11位就前面加0的參數,它不會在前面加0
聲明整型數據列時,我們可以為它指定個顯示寬度M(1~255),如INT(5),指定顯示寬度為5個字符,如果沒有給它指定顯示寬度,MySQL會為它指定一個默認值。顯示寬度只用于顯示,并不能限制取值范圍和占用空間,如:INT(3)會占用4個字節的存儲空間,并且允許的最大值也不會是999,而是 INT整型所允許的最大值。
MySQL有五種整型數據列類型,即TINYINT,SMALLINT,MEDIUMINT,INT和BIGINT。它們之間的區別是取值范圍不同,存儲空間也各不相同。?
在整型數據列后加上UNSIGNED屬性可以禁止負數,取值從0開始。
- 首先說一下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。下面的表顯示了需要的每個整數類型的存儲和范圍。
| 類型 | 字節 | 最小值(帶符號的) | 最大值(帶符號 |最小值(無符號)|最大值(無符號)|
| ------------- |:-------------:| -----:|
|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。當你想要在列內只允許非負數和該列需要較大的上限數值范圍時可以使用無符號值。所以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。
?
總結
以上是生活随笔為你收集整理的MySQL中述职类型的长度问题的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 高性能队列——Disruptor
- 下一篇: ArrayBlockingQueue跟L