每次看了每次都要忘.. 轉自http://bbs.nankai.edu.cn/
"
設計資料庫時候,我們習慣將儲存字串的欄位資料類型設定為char、varchar或nchar、nvarchar型,往往會忽略text和ntext類型也可以用來儲存字串,這幾種資料類型各有所長,各有所短,在效能和功能上也存在很大的差異。因而在設計的時候就需要選擇合適的類型儲存資料。下面簡單比較一下這幾種資料類型。 1、char。char儲存定長資料很方便,char欄位上的索引效率級高,比如定義char(10),那麼不論你儲存的資料是否達到了10個位元組,都要佔去10個位元組的空間,不足的自動用空格填充。 2、varchar。儲存變長資料,但儲存效率沒有char高。如果一個欄位可能的值是不固定長度的,我們只知道它不可能超過10個字元,把它定義為 varchar(10)是最合算的。varchar類型的實際長度是它的值的實際長度+1。為什麼“+1”呢?這一個位元組用於儲存實際使用了多大的長度。從空間上考慮,用varchar合適;從效率上考慮,用char合適,關鍵是根據實際情況找到權衡點。 3、nchar、nvarchar。從名字上看比前面兩種多了個“n”。它表示儲存的是Unicode資料類型的字元。我們知道字元中,英文字元只需要一個位元組儲存就足夠了,但漢字眾多,需要兩個位元組儲存,英文與漢字同時存在時容易造成混亂,Unicode字元集就是為瞭解決字元集這種不相容的問題而產生的,它所有的字元都用兩個位元組表示,即英文字元也是用兩個位元組表示。nchar、nvarchar的長度是在1到4000之間。和char、varchar比較起來,nchar、nvarchar則最多儲存4000個字元,不論是英文還是漢字;而char、varchar最多能儲存8000個英文,4000個漢字。可以看出使用nchar、nvarchar資料類型時不用擔心輸入的字元是英文還是漢字,較為方便,但在儲存英文時數量上有些損失。 3、text、ntext。由於sql server按資料頁儲存資料,每個資料頁8K, 而每個資料頁有一些管理資訊,因此每個資料頁用於儲存表記錄資料的空間是8060位元組,由於一條記錄只能儲存在一個資料頁上,不能跨頁,所以每個表的單條記錄總長度不能超過8060位元組。因此對於前面的幾種資料類型儲存,最大長度為8000位元組。因而在儲存一些長的字串的時候,前面的幾種類型就顯得力不從心了。text儲存可變長度的非unicode資料,最大長度為2^31-1(2,147,483,647)個字元,可以說這個長度可以滿足我們對字串長度的任意需求。ntext與text的關係,和char與nchar的關係一樣.
"