遇到一個(gè)問題,建的數(shù)據(jù)庫里的中文字符和音標(biāo)顯示為亂碼,所有字符都用varchar表示,所以出現(xiàn)上訴問題,當(dāng)改為Nvarchar后,問題得到解決。所以有必要把他們的區(qū)別再重新復(fù)習(xí)一遍。
char類型:對英文(ASCII)字符占用1個(gè)字節(jié),對一個(gè)漢字占用2個(gè)字節(jié),CHAR存儲(chǔ)定長數(shù)據(jù)很方便,CHAR字段上的索引效率級高,比如定義char(10),那么不論你存儲(chǔ)的數(shù)據(jù)是否達(dá)到了10個(gè)字節(jié),都要占去10個(gè)字節(jié)的空間。因?yàn)槭枪潭ㄩL度,所以速度效率高。
Varchar類型:Varchar 的類型不以空格填滿,比如varchar(100),但它的值只是"qian",則它的值就是"qian"
而char 不一樣,比如char(100),它的值是"qian",而實(shí)際上它在數(shù)據(jù)庫中是"qian "(qian后共有96個(gè)空格,就是把它填滿為100個(gè)字節(jié))。
由于char是以固定長度的,所以它的速度會(huì)比varchar快得多!但程序處理起來要麻煩一點(diǎn),要用trim之類的函數(shù)把兩邊的空格去掉!
VARCHAR存儲(chǔ)變長數(shù)據(jù),但存儲(chǔ)效率沒有CHAR高。如果一個(gè)字段可能的值是不固定長度的,我們只知道它不可能超過10個(gè)字符,把它定義為 VARCHAR(10)是最合算的。VARCHAR類型的實(shí)際長度是它的值的實(shí)際長度+1。為什么“+1”呢?這一個(gè)字節(jié)用于保存實(shí)際使用了多大的長度。
Nchar類型和Nvarchar類型是怎么一回事呢?為了與其他多種字符的轉(zhuǎn)換,如中文,音標(biāo)等,對每個(gè)英文(ASCII)字符都占用2個(gè)字節(jié),對一個(gè)漢字也占用兩個(gè)字節(jié),所有的字符都占用2個(gè)字節(jié)。
例如
varchar(n):變長型字符數(shù)據(jù)類型,存儲(chǔ)最長長度為8,000 個(gè)字符。
舉個(gè)例子:
insert a select '木子a'
--- 存儲(chǔ)長度為5個(gè)字節(jié),余下的3個(gè)字節(jié)全部釋放
insert a select '木神易
----存儲(chǔ)長度為6個(gè)字節(jié),余下的2個(gè)字節(jié)全部釋放
---意思是varchar變長字符數(shù)據(jù)類型與存儲(chǔ)數(shù)據(jù)的實(shí)際長度是一致的
nvarchar(n):可變長度 Unicode 數(shù)據(jù),其最大長度為 4,000 字符。
字節(jié)的存儲(chǔ)大小是所輸入字符個(gè)數(shù)的兩倍,
就是說它是雙字節(jié)來存儲(chǔ)數(shù)據(jù)的。
如果存儲(chǔ)數(shù)據(jù)如果存在單字節(jié)時(shí),它也是以雙字節(jié)來占用存儲(chǔ)空間的。
varchar一般適用于英文和數(shù)字,Nvarchar適用中文和其他字符,其中N表示Unicode常量,可以解決多語言字符集之間的轉(zhuǎn)換問題
ntext
可變長度 Unicode 數(shù)據(jù)的最大長度為 230 - 1 (1,073,741,823) 個(gè)字符。存儲(chǔ)大小是所輸入字符個(gè)數(shù)的兩倍(以字節(jié)為單位)。ntext 在 SQL-92 中的同義詞是 national text。
text
服務(wù)器代碼頁中的可變長度非 Unicode 數(shù)據(jù)的最大長度為 231-1 (2,147,483,647) 個(gè)字符。當(dāng)服務(wù)器代碼頁使用雙字節(jié)字符時(shí),存儲(chǔ)量仍是 2,147,483,647 字節(jié)。存儲(chǔ)大小可能小于 2,147,483,647 字節(jié)(取決于字符串)。