首頁>Club>
15
回覆列表
  • 1 # 金克斯fj384

    使用char 存英文字元一個佔一個位元組,存中文,一箇中文佔2個位元組,nchar存中英文都佔兩個位元組 對於程式中的string型欄位,SQLServer中有char、varchar、nchar、nvarchar四種類型來對應(暫時不考慮text和ntext),開建立資料庫中,對這四種類型往往比較模糊,這裡做一下對比。2.Unicode或非Unicode資料庫中,英文字元只需要一個位元組儲存就足夠了,但漢字和其他眾多非英文字元,則需要兩個位元組儲存。如果英文與漢字同時存在,由於佔用空間數不同,容易造成混亂,導致讀取出來的字串是亂碼。Unicode字符集就是為了解決字符集這種不相容的問題而產生的,它所有的字元都用兩個位元組表示,即英文字元也是用兩個位元組表示。而字首n就表示Unicode字元,比如nchar,nvarchar,這兩種型別使用了Unicode字符集。3.基於以上兩點來看看欄位容量char,varchar 最多8000個英文,4000個漢字 nchar,nvarchar 可儲存4000個字元,無論英文還是漢字 char、varchar、nchar、nvarchar特點比較從空間上考慮,用varchar合適;從效率上考慮,用char合適,關鍵是根據實際情況找到權衡點。NCHAR、NVARCHAR、NTEXT這三種從名字上看比前面三種多了個"N"。和char、varchar比較起來,nchar、nvarchar最多儲存4000個字元,不論是英文還是漢字;而char、varchar最多能儲存8000個英文,4000個漢字。可以看出使用nchar、nvarchar資料型別時不用擔心輸入的字元是英文還是漢字,較為方便,但在儲存英文時數量上有些損失。所以一般來說,如果含有中文字元,用nchar/nvarchar,如果純英文和數字,用char/varchar。

  • 中秋節和大豐收的關聯?
  • 懷孕期間什麼時候容易長妊娠斑?