明輝手游網(wǎng)中心:是一個(gè)免費(fèi)提供流行視頻軟件教程、在線(xiàn)學(xué)習(xí)分享的學(xué)習(xí)平臺(tái)!

char、varchar、nchar、nvarchar、text之間有哪一些區(qū)別

[摘要]char、varchar、nchar、nvarchar、text的區(qū)別1.有var前綴的,表示是實(shí)際存儲(chǔ)空間是變長(zhǎng)的,varchar,nvarchar所謂定長(zhǎng)就是長(zhǎng)度固定的,當(dāng)輸入的數(shù)據(jù)長(zhǎng)度沒(méi)有達(dá)到...
char、varchar、nchar、nvarchar、text的區(qū)別

1.有var前綴的,表示是實(shí)際存儲(chǔ)空間是變長(zhǎng)的,varchar,nvarchar

所謂定長(zhǎng)就是長(zhǎng)度固定的,當(dāng)輸入的數(shù)據(jù)長(zhǎng)度沒(méi)有達(dá)到指定的長(zhǎng)度時(shí)將自動(dòng)以英文空格在其后面填充,使長(zhǎng)度達(dá)到相應(yīng)的長(zhǎng)度,當(dāng)你輸入的字符大于指定的數(shù)時(shí),它會(huì)截取超出的部分;而變長(zhǎng)字符數(shù)據(jù)則不會(huì)以空格填充,比較例外的是,text存儲(chǔ)的也是可變長(zhǎng)。

2.n表示Unicode字符,即所有字符都占兩個(gè)字節(jié),nchar,nvarchar,

字符中,英文字符只需要一個(gè)字節(jié)存儲(chǔ)就足夠了,但漢字眾多,需要兩個(gè)字節(jié)存儲(chǔ),英文與漢字同時(shí)存在時(shí)容易造成混亂,Unicode字符集就是為了解決字符集這種不兼容的問(wèn)題而產(chǎn)生的,它所有的字符都用兩個(gè)字節(jié)表示,即英文字符也是用兩個(gè)字節(jié)表示

3.基于以上兩點(diǎn)來(lái)看看字段容量

char(n),varchar(n)最多8000個(gè)英文,4000個(gè)漢字n表示輸入數(shù)據(jù)的字節(jié)的實(shí)際長(zhǎng)度
nchar(n),nvarchar(n)可存儲(chǔ)4000個(gè)字符,無(wú)論英文還是漢字n表示字符個(gè)數(shù)

4.使用(個(gè)人偏好)

a.如果數(shù)據(jù)量非常大,又能100%確定長(zhǎng)度且保存只是ansi字符,那么char

b.能確定長(zhǎng)度又不一定是ansi字符或者,那么用nchar;

c.對(duì)于超大數(shù)據(jù),如文章內(nèi)容,使用nText

d.其他的通用nvarchar

特點(diǎn)比較

1、CHAR。CHAR存儲(chǔ)定長(zhǎng)數(shù)據(jù)很方便,CHAR字段上的索引效率級(jí)高,比如定義char(10),那么不論你存儲(chǔ)的數(shù)據(jù)是否達(dá)到了10個(gè)字節(jié),都要占去10個(gè)字節(jié)的空間。

2、VARCHAR。存儲(chǔ)變長(zhǎng)數(shù)據(jù),但存儲(chǔ)效率沒(méi)有CHAR高,如果一個(gè)字段可能的值是不固定長(zhǎng)度的,我們只知道它不可能超過(guò)10個(gè)字符,把它定義為 VARCHAR(10)是最合算的。VARCHAR類(lèi)型的實(shí)際長(zhǎng)度是它的值的實(shí)際長(zhǎng)度+1。為什么"+1"呢?這一個(gè)字節(jié)用于保存實(shí)際使用了多大的長(zhǎng)度。

從空間上考慮,用varchar合適;從效率上考慮,用char合適,關(guān)鍵是根據(jù)實(shí)際情況找到權(quán)衡點(diǎn)。

3、TEXT。text存儲(chǔ)可變長(zhǎng)度的非Unicode數(shù)據(jù),最大長(zhǎng)度為2^31-1(2,147,483,647)個(gè)字符。

4、NCHAR、NVARCHAR、NTEXT。這三種從名字上看比前面三種多了個(gè)"N"。和char、varchar比較起來(lái),nchar、nvarchar最多存儲(chǔ)4000個(gè)字符,不論是英文還是漢字;而char、varchar最多能存儲(chǔ)8000個(gè)英文,4000個(gè)漢字。可以看出使用nchar、nvarchar數(shù)據(jù)類(lèi)型時(shí)不用擔(dān)心輸入的字符是英文還是漢字,較為方便,但在存儲(chǔ)英文時(shí)數(shù)量上有些損失。

所以一般來(lái)說(shuō),如果含有中文字符,用nchar/nvarchar,如果純英文和數(shù)字,用char/varchar。

以上就是char、varchar、nchar、nvarchar、text之間有哪些區(qū)別的詳細(xì)內(nèi)容,更多請(qǐng)關(guān)注php中文網(wǎng)其它相關(guān)文章!


學(xué)習(xí)教程快速掌握從入門(mén)到精通的SQL知識(shí)。