欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL數(shù)據(jù)庫(kù)常見(jiàn)字段類(lèi)型長(zhǎng)度匯總大全

 更新時(shí)間:2024年05月23日 09:54:54   作者:程序員Forlan  
這篇文章主要給大家介紹了關(guān)于MySQL數(shù)據(jù)庫(kù)常見(jiàn)字段類(lèi)型長(zhǎng)度匯總大全的相關(guān)資料,需要的朋友可以參考下

一、整數(shù)

TINYINT

  • 長(zhǎng)度:固定為1個(gè)字節(jié)。
  • 范圍:-128 到 127(有符號(hào))或 0 到 255(無(wú)符號(hào))。

SMALLINT

  • 長(zhǎng)度:固定為2個(gè)字節(jié)。
  • 范圍:-32,768 到 32,767(有符號(hào))或 0 到 65,535(無(wú)符號(hào))。

MEDIUMINT

  • 長(zhǎng)度:固定為3個(gè)字節(jié)。
  • 范圍:-8,388,608 到 8,388,607(有符號(hào))或 0 到 16,777,215(無(wú)符號(hào))。

INT

  • 長(zhǎng)度:固定為4個(gè)字節(jié)。
  • 范圍:-2,147,483,648 到 2,147,483,647(有符號(hào))或 0 到 4,294,967,295(無(wú)符號(hào))。

BIGINT

  • 長(zhǎng)度:固定為8個(gè)字節(jié)。
  • 范圍:-9,223,372,036,854,775,808 到 9,223,372,036,854,775,807(有符號(hào))或 0 到 18,446,744,073,709,551,615(無(wú)符號(hào))。

二、字符串

CHAR

  • 長(zhǎng)度:0到255個(gè)字符。
  • 存儲(chǔ):定長(zhǎng),總是使用指定的長(zhǎng)度。如果存儲(chǔ)的字符串長(zhǎng)度小于定義的長(zhǎng)度,它將使用空格填充。

VARCHAR

  • 長(zhǎng)度:0到65535個(gè)字符,但實(shí)際最大長(zhǎng)度取決于最大行大?。?5535字節(jié))和使用的字符集。
  • 存儲(chǔ):變長(zhǎng),只使用必要的空間加上一個(gè)或兩個(gè)額外的字節(jié)來(lái)記錄字符串的長(zhǎng)度。

BINARY

  • 長(zhǎng)度:0到65535個(gè)字節(jié),取決于字符集和校對(duì)規(guī)則。
  • 存儲(chǔ):定長(zhǎng),總是使用指定的長(zhǎng)度。BINARY類(lèi)型類(lèi)似于CHAR類(lèi)型,但存儲(chǔ)二進(jìn)制字節(jié)字符串。

VARBINARY

  • 長(zhǎng)度:0到65535個(gè)字節(jié),取決于字符集和校對(duì)規(guī)則。
  • 存儲(chǔ):變長(zhǎng),只使用必要的空間加上一個(gè)額外的字節(jié)來(lái)記錄字符串的長(zhǎng)度。VARBINARY類(lèi)型類(lèi)似于VARCHAR類(lèi)型,但存儲(chǔ)二進(jìn)制字節(jié)字符串。

TINYTEXT

  • 長(zhǎng)度:最大255個(gè)字符。2^8 − 1
  • 存儲(chǔ):存儲(chǔ)長(zhǎng)度需要1個(gè)字節(jié),字符串本身存儲(chǔ)在單獨(dú)的表中。

TEXT

  • 長(zhǎng)度:最大65,535個(gè)字符。2^16 − 1
  • 存儲(chǔ):存儲(chǔ)長(zhǎng)度需要2個(gè)字節(jié),字符串本身存儲(chǔ)在單獨(dú)的表中。

MEDIUMTEXT

  • 長(zhǎng)度:最大16,777,215個(gè)字符。2^24 − 1
  • 存儲(chǔ):存儲(chǔ)長(zhǎng)度需要3個(gè)字節(jié),字符串本身存儲(chǔ)在單獨(dú)的表中。

LONGTEXT

  • 長(zhǎng)度:最大4,294,967,295個(gè)字符。2^32 − 1
  • 存儲(chǔ):存儲(chǔ)長(zhǎng)度需要4個(gè)字節(jié),字符串本身存儲(chǔ)在單獨(dú)的表中。

TINYBLOB

  • 長(zhǎng)度:最大255個(gè)字節(jié)。2^8 − 1
  • 存儲(chǔ):存儲(chǔ)長(zhǎng)度需要1個(gè)字節(jié),二進(jìn)制數(shù)據(jù)存儲(chǔ)在單獨(dú)的表中。

BLOB

  • 長(zhǎng)度:最大65,535個(gè)字節(jié)。2^16 − 1
  • 存儲(chǔ):存儲(chǔ)長(zhǎng)度需要2個(gè)字節(jié),二進(jìn)制數(shù)據(jù)存儲(chǔ)在單獨(dú)的表中。

MEDIUMBLOB

  • 長(zhǎng)度:最大16,777,215個(gè)字節(jié)。2^24 − 1
  • 存儲(chǔ):存儲(chǔ)長(zhǎng)度需要3個(gè)字節(jié),二進(jìn)制數(shù)據(jù)存儲(chǔ)在單獨(dú)的表中。

LONGBLOB

  • 長(zhǎng)度:最大4,294,967,295個(gè)字節(jié)。2^32 − 1
  • 存儲(chǔ):存儲(chǔ)長(zhǎng)度需要4個(gè)字節(jié),二進(jìn)制數(shù)據(jù)存儲(chǔ)在單獨(dú)的表中。

TEXT和BLOB字段類(lèi)型之間的主要區(qū)別?

  • 存儲(chǔ)內(nèi)容:
    TEXT:通常用于存儲(chǔ)長(zhǎng)文本內(nèi)容,如文章、評(píng)論等。
    BLOB:通常用于存儲(chǔ)二進(jìn)制數(shù)據(jù),如圖片、音頻、視頻等。
  • 最大長(zhǎng)度:
    TEXT:TINYTEXT 最多可存儲(chǔ) 255 個(gè)字符,TEXT 最多可存儲(chǔ) 65,535 個(gè)字符,MEDIUMTEXT 最多可存儲(chǔ) 16,777,215 個(gè)字符,LONGTEXT 最多可存儲(chǔ) 4,294,967,295 個(gè)字符。
    BLOB:TINYBLOB 最多可存儲(chǔ) 255 個(gè)字節(jié),BLOB 最多可存儲(chǔ) 65,535 個(gè)字節(jié),MEDIUMBLOB 最多可存儲(chǔ) 16,777,215 個(gè)字節(jié),LONGBLOB 最多可存儲(chǔ) 4,294,967,295 個(gè)字節(jié)。
  • 字符集和排序規(guī)則:
    TEXT:與字符集和排序規(guī)則相關(guān),因?yàn)樗鎯?chǔ)的是文本數(shù)據(jù)。
    BLOB:與字符集和排序規(guī)則無(wú)關(guān),因?yàn)樗鎯?chǔ)的是二進(jìn)制數(shù)據(jù)。
  • 存儲(chǔ)和檢索:
    TEXT:當(dāng)你存儲(chǔ)或檢索TEXT字段時(shí),MySQL會(huì)考慮字符集和排序規(guī)則。
    BLOB:對(duì)于BLOB字段,MySQL將其視為純粹的二進(jìn)制數(shù)據(jù),不會(huì)考慮字符集或排序規(guī)則。
  • 用途:
    TEXT:通常用于需要存儲(chǔ)和檢索大量文本數(shù)據(jù)的場(chǎng)景,如文章、評(píng)論等。
    BLOB:通常用于存儲(chǔ)大型二進(jìn)制對(duì)象,如圖片、音頻、視頻等,或者存儲(chǔ)與字符集和排序規(guī)則無(wú)關(guān)的數(shù)據(jù)。

選擇TEXT還是BLOB主要取決于你的數(shù)據(jù)需求和場(chǎng)景。如果你正在存儲(chǔ)大量的文本數(shù)據(jù),并且需要考慮到字符集和排序規(guī)則,那么TEXT可能是更好的選擇。如果你正在存儲(chǔ)大型二進(jìn)制對(duì)象或與字符集和排序規(guī)則無(wú)關(guān)的數(shù)據(jù),那么BLOB可能更適合你的需求。

三、浮點(diǎn)數(shù)

NUMERIC(M, D), DECIMAL(M, D)

  • 精度和標(biāo)度:M是精度(總位數(shù))從1到65,D是標(biāo)度(小數(shù)點(diǎn)后的位數(shù))從0到30。
  • 存儲(chǔ):取決于精度和標(biāo)度。根據(jù)指定的精度和標(biāo)度使用固定數(shù)量的字節(jié)。

FLOAT

FLOAT 是單精度浮點(diǎn)數(shù)數(shù)據(jù)類(lèi)型,用于存儲(chǔ)近似值。

FLOAT 類(lèi)型的數(shù)值可能會(huì)有舍入誤差,因?yàn)楦↑c(diǎn)數(shù)使用二進(jìn)制表示,無(wú)法精確表示某些十進(jìn)制小數(shù)。

存儲(chǔ):32位(4字節(jié))來(lái)存儲(chǔ)數(shù)值,并且可以存儲(chǔ)大約7位有效數(shù)字。

DOUBLE

DOUBLE 是雙精度浮點(diǎn)數(shù)數(shù)據(jù)類(lèi)型,也用于存儲(chǔ)近似值。

與 FLOAT 類(lèi)似,DOUBLE 類(lèi)型的數(shù)值也可能會(huì)有舍入誤

存儲(chǔ):使用64位(8字節(jié))來(lái)存儲(chǔ)數(shù)值,并且可以存儲(chǔ)大約15位有效數(shù)字。

浮點(diǎn)數(shù)的區(qū)別?

DECIMAL 和 NUMERIC 是精確數(shù)值類(lèi)型,用于需要精確計(jì)算的場(chǎng)景,如貨幣值。它們以字符串形式存儲(chǔ),不會(huì)引入舍入誤差。

FLOAT 和 DOUBLE 是浮點(diǎn)數(shù)類(lèi)型,用于存儲(chǔ)近似值。它們使用二進(jìn)制表示,可能會(huì)有舍入誤差。

DECIMAL 和 NUMERIC 需要指定精度和標(biāo)度,而 FLOAT 和 DOUBLE 則不需要。

存儲(chǔ)大小方面,DECIMAL 和 NUMERIC 的存儲(chǔ)大小根據(jù)指定的精度和標(biāo)度而定,而 FLOAT 固定為4字節(jié),DOUBLE 固定為8字節(jié)。

四、總結(jié)

選擇字段的原則

  • 通常更小的更好

    應(yīng)該盡量使用可以正確存儲(chǔ)數(shù)據(jù)的最小數(shù)據(jù)類(lèi)型,更小的數(shù)據(jù)類(lèi)型通常更快,因?yàn)樗鼈冋加酶俚拇疟P(pán)、內(nèi)存和CPU緩存,并且處理時(shí)需要的CPU更少,但是要確保沒(méi)有低估需要存儲(chǔ)的值的范圍,如果無(wú)法確認(rèn)哪個(gè)數(shù)據(jù)類(lèi)型,就選擇你認(rèn)為不會(huì)超過(guò)范圍的最小類(lèi)型

  • 簡(jiǎn)單就好

    簡(jiǎn)單數(shù)據(jù)類(lèi)型的操作,通常需要更少的CPU
    整型比字符操作代價(jià)更低,因?yàn)樽址淖址托?duì)規(guī)更復(fù)雜
    使用datetime類(lèi)型,使用MySQL自建類(lèi)型而不是字符串來(lái)存儲(chǔ)日期和時(shí)間
    用整型存儲(chǔ)IP地址,可以用函數(shù)把字符串轉(zhuǎn)成整型存,空間小,INET_ATON、INET_NTOA

  • 盡量避免null

    如果查詢(xún)中包含可為NULL的列,對(duì)MySQL來(lái)說(shuō)很難優(yōu)化,因?yàn)榭蔀閚ull的列使得索引、索引統(tǒng)計(jì)和值比較都更加復(fù)雜,坦白來(lái)說(shuō),通常情況下null的列改為not null帶來(lái)的性能提升比較小,所以沒(méi)有必要將所有的表的schema進(jìn)行修改,但是應(yīng)該盡量避免設(shè)計(jì)成可為null的列

int(1)定義的長(zhǎng)度影響寫(xiě)入的長(zhǎng)度?

這里的int(1)插入123可以成功的,只要不超過(guò)int類(lèi)型的表示范圍-2^31 - 2^31-1,所以說(shuō)字段括號(hào)的長(zhǎng)度是沒(méi)有意義的,不影響寫(xiě)入長(zhǎng)度。

varchar(5)與varchar(255)保存同樣的內(nèi)容,有區(qū)別?

我們知道,varchar(n) ,n<=255使用額外一個(gè)字節(jié)保存長(zhǎng)度,n>255使用額外兩個(gè)字節(jié)保存長(zhǎng)度。實(shí)際上,兩者的硬盤(pán)存儲(chǔ)空間相同,但內(nèi)存空間占用不同,是括號(hào)的指定大小,因?yàn)閷⑿袕拇鎯?chǔ)引擎層復(fù)制到SQL層時(shí),varchar將轉(zhuǎn)換為字段char以獲得利用固定寬度行的優(yōu)勢(shì),因此,內(nèi)存中的字符串將填充到聲明的varchar列的最大長(zhǎng)度。

具體可以查閱,MySQL官方文檔:https://dev.mysql.com/doc/refman/5.7/en/data-types.html

MySQL5.0.3版本之后varchar類(lèi)型的變化

1)、MySQL 5.0.3 之前:0-255字節(jié),如:varchar(20)中的20表示字節(jié)數(shù),如果存放utf-8編碼的話(huà)只能放6個(gè)漢字。varchar(n),這里的n表示字節(jié)數(shù)。

MySQL 5.0.3 之后:0-65535字節(jié),varchar(20)表示字符數(shù),不管什么編碼,既漢字也能放20個(gè)。但最多占65532字節(jié)(兩個(gè)字節(jié)存放長(zhǎng)度,小于255字節(jié)用1個(gè)字節(jié)存放長(zhǎng)度),varchar(n)這里的n表示

總結(jié) 

到此這篇關(guān)于MySQL數(shù)據(jù)庫(kù)常見(jiàn)字段類(lèi)型長(zhǎng)度匯總的文章就介紹到這了,更多相關(guān)MySQL常見(jiàn)字段類(lèi)型長(zhǎng)度內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Mysql事項(xiàng),視圖,函數(shù),觸發(fā)器命令(詳解)

    Mysql事項(xiàng),視圖,函數(shù),觸發(fā)器命令(詳解)

    下面小編就為大家?guī)?lái)一篇Mysql事項(xiàng),視圖,函數(shù),觸發(fā)器命令(詳解)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-11-11
  • 解決大于5.7版本mysql的分組報(bào)錯(cuò)Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated

    解決大于5.7版本mysql的分組報(bào)錯(cuò)Expression #1 of SELECT list is not in GR

    這篇文章主要介紹了解決大于5.7版本mysql的分組報(bào)錯(cuò)Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated問(wèn)題,需要的朋友可以參考下
    2019-10-10
  • MySQL生成千萬(wàn)測(cè)試數(shù)據(jù)以及遇到的問(wèn)題

    MySQL生成千萬(wàn)測(cè)試數(shù)據(jù)以及遇到的問(wèn)題

    前兩天發(fā)現(xiàn)同事要做一個(gè)對(duì)大表進(jìn)行范圍查詢(xún)的功能,所以需要生成千萬(wàn)數(shù)據(jù)進(jìn)行性能測(cè)試,下面這篇文章主要給大家介紹了關(guān)于MySQL生成千萬(wàn)測(cè)試數(shù)據(jù)以及遇到的問(wèn)題的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-08-08
  • Mysql應(yīng)用安裝后找不到my.ini文件的解決過(guò)程

    Mysql應(yīng)用安裝后找不到my.ini文件的解決過(guò)程

    剛剛在修改mysql默認(rèn)配置的時(shí)候,發(fā)現(xiàn)找不到my.ini文件,下面這篇文章主要給大家介紹了關(guān)于Mysql應(yīng)用安裝后找不到my.ini文件的解決過(guò)程,文中通過(guò)圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2022-08-08
  • MySQL實(shí)現(xiàn)定時(shí)自動(dòng)備份的流程步驟(Windows環(huán)境)

    MySQL實(shí)現(xiàn)定時(shí)自動(dòng)備份的流程步驟(Windows環(huán)境)

    這篇文章主要介紹了MySQL實(shí)現(xiàn)定時(shí)自動(dòng)備份的流程步驟(Windows環(huán)境),文中通過(guò)圖文結(jié)合的方式介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下
    2024-12-12
  • Mysql架構(gòu)圖解讀

    Mysql架構(gòu)圖解讀

    這篇文章主要介紹了Mysql架構(gòu)圖,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-08-08
  • 解決阿里云ECS服務(wù)器下安裝MySQL無(wú)法遠(yuǎn)程連接的問(wèn)題

    解決阿里云ECS服務(wù)器下安裝MySQL無(wú)法遠(yuǎn)程連接的問(wèn)題

    這篇文章介紹了解決阿里云ECS服務(wù)器安裝MySQL無(wú)法遠(yuǎn)程連接的方法,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-07-07
  • 修改MYSQL最大連接數(shù)的3種方法分享

    修改MYSQL最大連接數(shù)的3種方法分享

    MYSQL數(shù)據(jù)庫(kù)安裝完成后,默認(rèn)最大連接數(shù)是100,一般流量稍微大一點(diǎn)的論壇或網(wǎng)站這個(gè)連接數(shù)是遠(yuǎn)遠(yuǎn)不夠的,增加默認(rèn)MYSQL連接數(shù)的方法有好幾個(gè),這里簡(jiǎn)單分享下
    2011-05-05
  • 一文了解mysql索引的數(shù)據(jù)結(jié)構(gòu)為什么要用B+樹(shù)

    一文了解mysql索引的數(shù)據(jù)結(jié)構(gòu)為什么要用B+樹(shù)

    這篇文章主要介紹了一文了解mysql索引的數(shù)據(jù)結(jié)構(gòu)為什么用B+樹(shù),在節(jié)點(diǎn)中存儲(chǔ)某段數(shù)據(jù)的首地址,并且B+樹(shù)的葉子節(jié)點(diǎn)用了一個(gè)鏈表串聯(lián)起來(lái),便于范圍查找,下文利用各種索引的數(shù)據(jù)結(jié)構(gòu)的方法與B+樹(shù)做對(duì)比,看看它的優(yōu)勢(shì)到底是什么,感興趣的小伙伴可以參考一下
    2022-04-04
  • mysql分析sql是否成功使用索引的步驟詳解

    mysql分析sql是否成功使用索引的步驟詳解

    在MySQL中,可以通過(guò)使用EXPLAIN語(yǔ)句來(lái)分析SQL查詢(xún)是否成功使用了索引,本文給大家介紹了使用EXPLAIN語(yǔ)句分析SQL語(yǔ)句是否成功使用索引的步驟,需要的朋友可以參考下
    2023-12-12

最新評(píng)論