日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 运维知识 > 数据库 >内容正文

数据库

MySQL中述职类型的长度问题

發(fā)布時(shí)間:2024/1/17 数据库 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 MySQL中述职类型的长度问题 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

int(M) M指示最大顯示寬度。最大有效顯示寬度是255。顯示寬度與存儲(chǔ)大小或類(lèi)型包含的值的范圍無(wú)關(guān)

?

在SQL語(yǔ)句中int代表你要?jiǎng)?chuàng)建字段的類(lèi)型,int代表整型,11代表字段的長(zhǎng)度。

 這個(gè)11代表顯示寬度,整數(shù)列的顯示寬度與mysql需要用多少個(gè)字符來(lái)顯示該列數(shù)值,與該整數(shù)需要的存儲(chǔ)空間的大小都沒(méi)有關(guān)系,比如,不管設(shè)定了顯示寬度是多少個(gè)字符,bigint都要占用8個(gè)字節(jié)。

  int是整型,(11)是指顯示字符的長(zhǎng)度,但要加參數(shù)的,最大為255,比如它是記錄行數(shù)的id,插入10筆資料,它就顯示00000000001 ~~~00000000010,當(dāng)字符的位數(shù)超過(guò)11,它也只顯示11位,如果你沒(méi)有加那個(gè)讓它未滿11位就前面加0的參數(shù),它不會(huì)在前面加0

  聲明整型數(shù)據(jù)列時(shí),我們可以為它指定個(gè)顯示寬度M(1~255),如INT(5),指定顯示寬度為5個(gè)字符,如果沒(méi)有給它指定顯示寬度,MySQL會(huì)為它指定一個(gè)默認(rèn)值。顯示寬度只用于顯示,并不能限制取值范圍和占用空間,如:INT(3)會(huì)占用4個(gè)字節(jié)的存儲(chǔ)空間,并且允許的最大值也不會(huì)是999,而是 INT整型所允許的最大值。

  MySQL有五種整型數(shù)據(jù)列類(lèi)型,即TINYINT,SMALLINT,MEDIUMINT,INT和BIGINT。它們之間的區(qū)別是取值范圍不同,存儲(chǔ)空間也各不相同。?
在整型數(shù)據(jù)列后加上UNSIGNED屬性可以禁止負(fù)數(shù),取值從0開(kāi)始。

  • 首先說(shuō)一下mysql的數(shù)值類(lèi)型,mysql支持所有標(biāo)準(zhǔn)SQL數(shù)值數(shù)據(jù)類(lèi)型。這些類(lèi)型包括嚴(yán)格數(shù)值數(shù)據(jù)類(lèi)型(INTEGER、SMALLINT、DECIMAL和NUMERIC),以及近似數(shù)值數(shù)據(jù)類(lèi)型(FLOAT、REAL和DOUBLE PRECISION)。關(guān)鍵字INT是INTEGER的同義詞,關(guān)鍵字DEC是DECIMAL的同義詞。
  • BIT數(shù)據(jù)類(lèi)型保存位字段值,并且支持MyISAM、MEMORY、InnoDB和BDB表。
  • 作為SQL標(biāo)準(zhǔn)的擴(kuò)展,MySQL也支持整數(shù)類(lèi)型TINYINT、MEDIUMINT和BIGINT。下面的表顯示了需要的每個(gè)整數(shù)類(lèi)型的存儲(chǔ)和范圍。

| 類(lèi)型 | 字節(jié) | 最小值(帶符號(hào)的) | 最大值(帶符號(hào) |最小值(無(wú)符號(hào))|最大值(無(wú)符號(hào))|
| ------------- |:-------------:| -----:|
|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類(lèi)型關(guān)鍵字后面的括號(hào)內(nèi)指定整數(shù)值的顯示寬度(例如,INT(4))。該可選顯示寬度規(guī)定用于顯示寬度小于指定的列寬度的值時(shí)從左側(cè)填滿寬度。顯示寬度并不限制可以在列內(nèi)保存的值的范圍,也不限制超過(guò)列的指定寬度的值的顯示。

  • 當(dāng)結(jié)合可選擴(kuò)展屬性ZEROFILL使用時(shí), 默認(rèn)補(bǔ)充的空格用零代替。例如,對(duì)于聲明為INT(5) ZEROFILL的列,值4檢索為00004。請(qǐng)注意如果在整數(shù)列保存超過(guò)顯示寬度的一個(gè)值,當(dāng)MySQL為復(fù)雜聯(lián)接生成臨時(shí)表時(shí)會(huì)遇到問(wèn)題,因?yàn)樵谶@些情況下MySQL相信數(shù)據(jù)適合原列寬度。

  • 所有整數(shù)類(lèi)型可以有一個(gè)可選(非標(biāo)準(zhǔn))屬性UNSIGNED。當(dāng)你想要在列內(nèi)只允許非負(fù)數(shù)和該列需要較大的上限數(shù)值范圍時(shí)可以使用無(wú)符號(hào)值。所以int(10)與int(11)后的括號(hào)中的字符表示顯示寬度,整數(shù)列的顯示寬度與mysql需要用多少個(gè)字符來(lái)顯示該列數(shù)值,與該整數(shù)需要的存儲(chǔ)空間的大小都沒(méi)有關(guān)系,int類(lèi)型的字段能存儲(chǔ)的數(shù)據(jù)上限還是2147483647(有符號(hào)型)和4294967295(無(wú)符號(hào)型)。

  • 浮點(diǎn)和定點(diǎn)類(lèi)型也可以為UNSIGNED。同數(shù)類(lèi)型,該屬性防止負(fù)值保存到列中。然而,與整數(shù)類(lèi)型不同的是,列值的上范圍保持不變。如果為一個(gè)數(shù)值列指定ZEROFILL,MySQL自動(dòng)為該列添加UNSIGNED屬性。對(duì)于浮點(diǎn)列類(lèi)型,在MySQL中單精度值使用4個(gè)字節(jié),雙精度值使用8個(gè)字節(jié)。

  • FLOAT類(lèi)型用于表示近似數(shù)值數(shù)據(jù)類(lèi)型。SQL標(biāo)準(zhǔn)允許在關(guān)鍵字FLOAT后面的括號(hào)內(nèi)選擇用位指定精度(但不能為指數(shù)范圍)。MySQL還支持可選的只用于確定存儲(chǔ)大小的精度規(guī)定。0到23的精度對(duì)應(yīng)FLOAT列的4字節(jié)單精度。24到53的精度對(duì)應(yīng)DOUBLE列的8字節(jié)雙精度。

  • MySQL允許使用非標(biāo)準(zhǔn)語(yǔ)法:FLOAT(M,D)或REAL(M,D)或DOUBLE PRECISION(M,D)。這里,“(M,D)”表示該值一共顯示M位整數(shù),其中D位位于小數(shù)點(diǎn)后面。例如,定義為FLOAT(7,4)的一個(gè)列可以顯示為-999.9999。MySQL保存值時(shí)進(jìn)行四舍五入,因此如果在FLOAT(7,4)列內(nèi)插入999.00009,近似結(jié)果是999.0001。

  • MySQL將DOUBLE視為DOUBLE PRECISION(非標(biāo)準(zhǔn)擴(kuò)展)的同義詞。MySQL還將REAL視為DOUBLE PRECISION(非標(biāo)準(zhǔn)擴(kuò)展)的同義詞,除非SQL服務(wù)器模式包括REAL_AS_FLOAT選項(xiàng)。

  • 為了保證最大可能的可移植性,需要使用近似數(shù)值數(shù)據(jù)值存儲(chǔ)的代碼應(yīng)使用FLOAT或DOUBLE PRECISION,不規(guī)定精度或位數(shù)。
    DECIMAL和NUMERIC類(lèi)型在MySQL中視為相同的類(lèi)型。它們用于保存必須為確切精度的值,例如貨幣數(shù)據(jù)。當(dāng)聲明該類(lèi)型的列時(shí),可以(并且通常要)指定精度和標(biāo)度;例如:salary DECIMAL(5,2)在該例子中,5是精度,2是標(biāo)度。精度表示保存值的主要位數(shù),標(biāo)度表示小數(shù)點(diǎn)后面可以保存的位數(shù)。

  • 在MySQL 5.1中以二進(jìn)制格式保存DECIMAL和NUMERIC值。
    標(biāo)準(zhǔn)SQL要求salary列能夠用5位整數(shù)位和兩位小數(shù)保存任何值。因此,在這種情況下可以保存在salary列的值的范圍是從-999.99到999.99。

  • 在標(biāo)準(zhǔn)SQL中,語(yǔ)法DECIMAL(M)等價(jià)于DECIMAL(M,0)。同樣,語(yǔ)法DECIMAL等價(jià)于DECIMAL(M,0),可以通過(guò)計(jì)算確定M的值。在MySQL 5.1中支持DECIMAL和NUMERIC數(shù)據(jù)類(lèi)型的變量形式。M默認(rèn)值是10。

  • DECIMAL或NUMERIC的最大位數(shù)是65,但具體的DECIMAL或NUMERIC列的實(shí)際范圍受具體列的精度或標(biāo)度約束。如果此類(lèi)列分配的值小數(shù)點(diǎn)后面的位數(shù)超過(guò)指定的標(biāo)度允許的范圍,值被轉(zhuǎn)換為該標(biāo)度。(具體操作與操作系統(tǒng)有關(guān),但一般結(jié)果均被截取到允許的位數(shù))。

  • BIT數(shù)據(jù)類(lèi)型可用來(lái)保存位字段值。BIT(M)類(lèi)型允許存儲(chǔ)M位值。M范圍為1到64。

  • 要指定位值,可以使用b’value’符。value是一個(gè)用0和1編寫(xiě)的二進(jìn)制值。例如,b’111′和b’100000000′分別表示7和128。

?

總結(jié)

以上是生活随笔為你收集整理的MySQL中述职类型的长度问题的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。