SQL SERVER資料庫中的資料類型 轉

來源:互聯網
上載者:User

每次看了每次都要忘.. 轉自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的關係一樣.

"

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.