婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 基于SQL Server中char,nchar,varchar,nvarchar的使用區(qū)別

基于SQL Server中char,nchar,varchar,nvarchar的使用區(qū)別

熱門標簽:北京400電話辦理多少錢 浙江穩(wěn)定外呼系統(tǒng)供應商 怎么給高德做地圖標注 慶陽地圖標注 承德地圖標注公司名需要花錢嗎 美團地圖標注商戶認證注冊 榕城市地圖標注 電銷外呼系統(tǒng)軟件功能 咸陽電腦外呼系統(tǒng)運營商

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

1.定長或變長

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

2.Unicode或非Unicode

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

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

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

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

復制代碼 代碼如下:

--創(chuàng)建表
CREATE TABLE TempTable(
    id INT PRIMARY KEY,
    charField CHAR(10),
    varcharField VARCHAR(10),
    nvarcharField NVARCHAR(10)
)

INSERT INTO TempTable VALUES(1,'WFTH','WFTH','WFTH') 
INSERT INTO TempTable VALUES(2,'無風聽海','無風聽海','無風聽海')
INSERT INTO TempTable VALUES(3,'','','')
INSERT INTO TempTable(id) VALUES(4)
INSERT INTO TempTable VALUES(5,'1234567890','1234567890','12345')

SELECT DATALENGTH(charField) AS charFieldLen,
       DATALENGTH(varcharField) AS varcharFieldLen,
       DATALENGTH(nvarcharField) AS nvarcharFieldLen
FROM temptable WHERE id =1

SELECT DATALENGTH(charField) AS charFieldLen,
       DATALENGTH(varcharField) AS varcharFieldLen,
       DATALENGTH(nvarcharField) AS nvarcharFieldLen
FROM temptable WHERE id =2

SELECT DATALENGTH(charField) AS charFieldLen,
       DATALENGTH(varcharField) AS varcharFieldLen,
       DATALENGTH(nvarcharField) AS nvarcharFieldLen
FROM temptable WHERE id =3

SELECT DATALENGTH(charField) AS charFieldLen,
       DATALENGTH(varcharField) AS varcharFieldLen,
       DATALENGTH(nvarcharField) AS nvarcharFieldLen
FROM temptable WHERE id =4

SELECT DATALENGTH(charField) AS charFieldLen,charField,
       DATALENGTH(varcharField) AS varcharFieldLen,varcharField,
       DATALENGTH(nvarcharField) AS nvarcharFieldLen,nvarcharField
FROM temptable WHERE id =5

您可能感興趣的文章:
  • sql中varchar和nvarchar的區(qū)別與使用方法
  • 過程需要參數(shù) ''@statement'' 為 ''ntext/nchar/nvarchar'' 類型
  • Sqlserver中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類型中的特殊字符

標簽:新鄉(xiāng) 江蘇 拉薩 貴州 呼和浩特 昭通 上海 重慶

巨人網絡通訊聲明:本文標題《基于SQL Server中char,nchar,varchar,nvarchar的使用區(qū)別》,本文關鍵詞  基于,SQL,Server,中,char,nchar,;如發(fā)現(xiàn)本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《基于SQL Server中char,nchar,varchar,nvarchar的使用區(qū)別》相關的同類信息!
  • 本頁收集關于基于SQL Server中char,nchar,varchar,nvarchar的使用區(qū)別的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 珲春市| 沙田区| 嘉兴市| 沂南县| 新田县| 宜城市| 临漳县| 会泽县| 鸡东县| 宜章县| 巴东县| 红桥区| 曲阜市| 姚安县| 蓝田县| 淮南市| 朝阳区| 赫章县| 无为县| 长沙市| 遵化市| 讷河市| 呼玛县| 扎鲁特旗| 望奎县| 铜川市| 宁海县| 鸡泽县| 九龙城区| 大姚县| 双鸭山市| 新巴尔虎右旗| 泰来县| 神农架林区| 吉水县| 许昌县| 剑阁县| 荆州市| 宿松县| 靖州| 玛多县|