• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            twzheng's cppblog

            『站在風(fēng)口浪尖緊握住鼠標(biāo)旋轉(zhuǎn)!』 http://www.cnblogs.com/twzheng

              C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
              136 隨筆 :: 78 文章 :: 353 評(píng)論 :: 0 Trackbacks
            SQL中char、varchar、text和nchar、nvarchar、ntext的區(qū)別


                 1、CHAR。CHAR存儲(chǔ)定長(zhǎng)數(shù)據(jù)很方便,CHAR字段上的索引效率級(jí)高,比如定義char(10),那么不論你存儲(chǔ)的數(shù)據(jù)是否達(dá)到了10個(gè)字節(jié),都要占去10個(gè)字節(jié)的空間。
                 2、VARCHAR。存儲(chǔ)變長(zhǎng)數(shù)據(jù),但存儲(chǔ)效率沒有CHAR高。如果一個(gè)字段可能的值是不固定長(zhǎng)度的,我們只知道它不可能超過10個(gè)字符,把它定義為 VARCHAR(10)是最合算的。VARCHAR類型的實(shí)際長(zhǎng)度是它的值的實(shí)際長(zhǎng)度+1。為什么“+1”呢?這一個(gè)字節(jié)用于保存實(shí)際使用了多大的長(zhǎng)度。
                從空間上考慮,用varchar合適;從效率上考慮,用char合適,關(guān)鍵是根據(jù)實(shí)際情況找到權(quán)衡點(diǎn)。
                3、TEXT。text存儲(chǔ)可變長(zhǎng)度的非Unicode數(shù)據(jù),最大長(zhǎng)度為2^31-1(2,147,483,647)個(gè)字符。
                 4、NCHAR、NVARCHAR、NTEXT。這三種從名字上看比前面三種多了個(gè)“N”。它表示存儲(chǔ)的是Unicode數(shù)據(jù)類型的字符。我們知道字符中,英文字符只需要一個(gè)字節(jié)存儲(chǔ)就足夠了,但漢字眾多,需要兩個(gè)字節(jié)存儲(chǔ),英文與漢字同時(shí)存在時(shí)容易造成混亂,Unicode字符集就是為了解決字符集這種不兼容的問題而產(chǎn)生的,它所有的字符都用兩個(gè)字節(jié)表示,即英文字符也是用兩個(gè)字節(jié)表示。nchar、nvarchar的長(zhǎng)度是在1到4000之間。和char、varchar比較起來,nchar、nvarchar則最多存儲(chǔ)4000個(gè)字符,不論是英文還是漢字;而char、varchar最多能存儲(chǔ)8000個(gè)英文,4000個(gè)漢字。可以看出使用nchar、nvarchar數(shù)據(jù)類型時(shí)不用擔(dān)心輸入的字符是英文還是漢字,較為方便,但在存儲(chǔ)英文時(shí)數(shù)量上有些損失。
                 所以一般來說,如果含有中文字符,用nchar/nvarchar,如果純英文和數(shù)字,用char/varchar。
            posted on 2007-11-29 15:10 譚文政 閱讀(804) 評(píng)論(1)  編輯 收藏 引用 所屬分類: 數(shù)據(jù)庫

            評(píng)論

            # re: SQL中char、varchar、text和nchar、nvarchar、ntext的區(qū)別 2008-12-14 15:48 譚文政
            nvarchar(10) 不論是漢字(2個(gè)字節(jié))或字符(一個(gè)字節(jié)),均只能存10個(gè)。
            varchar(10) 只能存10個(gè)字節(jié)的字符,漢字算兩個(gè)字節(jié)。
            char(10) 固定10個(gè)字節(jié)的長(zhǎng)度,漢字算兩個(gè)字節(jié),不足部分會(huì)自動(dòng)補(bǔ)空格。
            nchar(10) 固定10個(gè)Unicode字符(2個(gè)字節(jié))的長(zhǎng)度,不足部分會(huì)自動(dòng)補(bǔ)空格。
            text(16) text允許的最小長(zhǎng)度是16,但實(shí)際存儲(chǔ)的字符串可以遠(yuǎn)遠(yuǎn)超過16個(gè)字符(好像是這樣的)。  回復(fù)  更多評(píng)論
              

            人妻无码久久一区二区三区免费 | 久久久久亚洲AV无码麻豆| 伊人久久大香线蕉av不卡| 久久国产色AV免费看| 精品综合久久久久久97超人| 国产精品美女久久久久AV福利| 精品久久久久久久中文字幕| 久久中文字幕人妻熟av女| 国内精品久久久久久99蜜桃| 久久久久亚洲?V成人无码| 99精品国产99久久久久久97| 99久久国产综合精品五月天喷水 | 7777精品伊人久久久大香线蕉| 亚洲精品无码久久久久sm| 国产精品亚洲美女久久久| 久久久国产打桩机| 国产免费久久精品丫丫| 久久久一本精品99久久精品66 | 久久久久国产视频电影| 无码AV波多野结衣久久| 亚洲国产精品综合久久一线| 久久久综合九色合综国产| 日韩人妻无码精品久久久不卡| 久久久久九九精品影院| 色成年激情久久综合| 久久国产精品无码HDAV| 亚洲综合日韩久久成人AV| 欧美日韩中文字幕久久久不卡| 777久久精品一区二区三区无码| 亚洲中文字幕久久精品无码APP| 久久久久亚洲精品天堂久久久久久| 国产精品久久国产精麻豆99网站| 亚洲日本va中文字幕久久| 久久毛片一区二区| 伊人久久成人成综合网222| 久久综合色区| 久久久久久久综合狠狠综合| 久久综合色区| 久久久久久伊人高潮影院| 无码国内精品久久人妻麻豆按摩 | 天堂无码久久综合东京热|