濮阳杆衣贸易有限公司

主頁 > 知識庫 > Sqlserver中char,nchar,varchar與Nvarchar的區(qū)別分析

Sqlserver中char,nchar,varchar與Nvarchar的區(qū)別分析

熱門標簽:最新人工智能電銷機器人 成都電話外呼系統(tǒng)一般多少錢 陜西電銷外呼系統(tǒng)好用嗎 al智能電話機器人 銀川高頻外呼回撥系統(tǒng)多少錢 如何做地圖標注圖鋪 蘭州語音外呼系統(tǒng)運營商 沒聽見電話機器人幫你接 數(shù)字匠心電銷機器人
1. char類型

對英文(ASCII)字符占用1個字節(jié),對一個漢字占用2個字節(jié),CHAR存儲定長數(shù)據(jù)很方便,CHAR字段上的索引效率極高,比如定義char(10),那么不論你存儲的數(shù)據(jù)是否達  到了10個字節(jié),都要占去10個字節(jié)的空間。因為是固定長度,所以速度效率高。比如定義char(10),那么不論你存儲的數(shù)據(jù)是否達到了10個字節(jié),都要占去10個字節(jié)的空間。因為是固定長度,所以速度效率高。

2. VARCHAR存儲變長數(shù)據(jù)

如果一個字段可能的值是不固定長度的,我們只知道它不可能超過10個字符,把它定義為 VARCHAR(10)是最合算的。VARCHAR類型的實際長度是它的值的實際長度+1。為什么“+1”呢?這一個字節(jié)用于保存實際使用了多大的長度。
   Varchar類型:Varchar 的類型不以空格填滿,而Char則會填充滿為止,如varchar(100),但它的值只是"qian",所以它在數(shù)據(jù)庫中存的值就是"qian",而char 不一樣,如char(100),它的  值是"qian",而實際上它在數(shù)據(jù)庫中是"qian "(qian后共有96個空格,就是把它填滿為100個字節(jié))。
注:由于char是以固定長度的,所以它的速度會比varchar快得多!但程序處理起來要麻煩一點,要用trim之類的函數(shù)把兩邊的空格去掉!
3. Nchar類型和Nvarchar類型是怎么一回事呢?

為了與其他多種字符的轉(zhuǎn)換,如中文,音標等,對每個英文(ASCII)字符都占用2個字節(jié),對一個漢字也占用兩個字節(jié),所有的字符都占用2個字節(jié)。

  varchar(n):變長型字符數(shù)據(jù)類型,存儲最長長度為8,000 個字符
  nvarchar(n):可變長度 Unicode 數(shù)據(jù),其最大長度為 4,000 字符.字節(jié)的存儲大小是所輸入字符個數(shù)的兩倍,就是說它是雙字節(jié)來存儲數(shù)據(jù)的。如果存儲數(shù)據(jù)如果存在單字節(jié)時,它也是以雙字節(jié)來占用存儲空間的。

  varchar一般適用于英文和數(shù)字,Nvarchar適用中文和其他字符,其中N表示Unicode常量,可以解決多語言字符集之間的轉(zhuǎn)換問題。

以下是補充:

對于程序中的一般字符串類型的字段,SQL Server中有char、varchar、nchar、nvarchar四種類型來對應(yīng),那么這四種類型有什么區(qū)別呢,這里做一下對比。

1.定長或變長

所謂定長就是長度固定,當要保存的數(shù)據(jù)長度不夠時將自動在其后面填充英文空格,使長度達到相應(yīng)的長度;有var前綴的,表示是實際存儲空間是動態(tài)變化的,比如varchar,nvarchar變長字符數(shù)據(jù)則不會以空格填充。

2.Unicode或非Unicode

數(shù)據(jù)庫中,英文字符只需要一個字節(jié)存儲就足夠了,但漢字和其他眾多非英文字符,則需要兩個字節(jié)存儲。如果英文與漢字同時存在,由于占用空間數(shù)不同,容易造成混亂,導致讀取出來的字符串是亂碼。Unicode字符集就是為了解決字符集這種不兼容的問題而產(chǎn)生的,它所有的字符都用兩個字節(jié)表示,即英文字符也是用兩個字節(jié)表示。而前綴n就表示Unicode字符,比如nchar,nvarchar,這兩種類型使用了Unicode字符集。

3.幾種數(shù)據(jù)類型的存儲的最大容量

char,varchar 最多8000個英文,4000個漢字

nchar,nvarchar  最多可存儲4000個字符,無論英文還是漢字

您可能感興趣的文章:
  • sql中varchar和nvarchar的區(qū)別與使用方法
  • 過程需要參數(shù) ''@statement'' 為 ''ntext/nchar/nvarchar'' 類型
  • 基于SQL Server中char,nchar,varchar,nvarchar的使用區(qū)別
  • 深入char、varchar、text和nchar、nvarchar、ntext的區(qū)別詳解
  • SQL2005中char nchar varchar nvarchar數(shù)據(jù)類型的區(qū)別和使用環(huán)境講解
  • SQL Server數(shù)據(jù)類型char、nchar、varchar、nvarchar的區(qū)別淺析
  • SQL中varchar和nvarchar的基本介紹及其區(qū)別
  • mysql如何處理varchar與nvarchar類型中的特殊字符

標簽:邢臺 宜春 朔州 本溪 巴彥淖爾 鹽城 通化 遼源

巨人網(wǎng)絡(luò)通訊聲明:本文標題《Sqlserver中char,nchar,varchar與Nvarchar的區(qū)別分析》,本文關(guān)鍵詞  Sqlserver,中,char,nchar,varchar,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Sqlserver中char,nchar,varchar與Nvarchar的區(qū)別分析》相關(guān)的同類信息!
  • 本頁收集關(guān)于Sqlserver中char,nchar,varchar與Nvarchar的區(qū)別分析的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    河间市| 金溪县| 醴陵市| 田东县| 秭归县| 卢氏县| 宣武区| 英山县| 双辽市| 澄江县| 奉新县| 福鼎市| 策勒县| 乐昌市| 平武县| 焉耆| 永善县| 铅山县| 台前县| 页游| 南开区| 宁城县| 九龙城区| 扎鲁特旗| 汽车| 靖边县| 冀州市| 博客| 湘潭县| 星子县| 秀山| 忻城县| 漳州市| 兴隆县| 平陆县| 郧西县| 荃湾区| 淮安市| 莒南县| 上饶市| 丹寨县|