• <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>

            牽著老婆滿街逛

            嚴以律己,寬以待人. 三思而后行.
            GMail/GTalk: yanglinbo#google.com;
            MSN/Email: tx7do#yahoo.com.cn;
            QQ: 3 0 3 3 9 6 9 2 0 .

            nchar,char,varchar與nvarchar區(qū)別

            http://www.builder.com.cn/2007/0730/438663.shtml

            1、CHAR。CHAR存儲定長數(shù)據(jù)很方便,CHAR字段上的索引效率級高,比如定義char(10),那么不論你存儲的數(shù)據(jù)是否達到了10個字節(jié),都要占去10個字節(jié)的空間,不足的自動用空格填充。

            2、VARCHAR。存儲變長數(shù)據(jù),但存儲效率沒有CHAR高。如果一個字段可能的值是不固定長度的,我們只知道它不可能超過10個字符,把它定義為 VARCHAR(10)是最合算的。VARCHAR類型的實際長度是它的值的實際長度+1。為什么“+1”呢?這一個字節(jié)用于保存實際使用了多大的長度。從空間上考慮,用varchar合適;從效率上考慮,用char合適,關鍵是根據(jù)實際情況找到權衡點。

            3、TEXT。text存儲可變長度的非Unicode數(shù)據(jù),最大長度為2^31-1(2,147,483,647)個字符。

            4、NCHAR、NVARCHAR、NTEXT。這三種從名字上看比前面三種多了個“N”。它表示存儲的是Unicode數(shù)據(jù)類型的字符。我們知道字符中,英文字符只需要一個字節(jié)存儲就足夠了,但漢字眾多,需要兩個字節(jié)存儲,英文與漢字同時存在時容易造成混亂,Unicode字符集就是為了解決字符集這種不兼容的問題而產(chǎn)生的,它所有的字符都用兩個字節(jié)表示,即英文字符也是用兩個字節(jié)表示。nchar、nvarchar的長度是在1到4000之間。和char、varchar比較起來,nchar、nvarchar則最多存儲4000個字符,不論是英文還是漢字;而char、varchar最多能存儲8000個英文,4000個漢字。可以看出使用nchar、nvarchar數(shù)據(jù)類型時不用擔心輸入的字符是英文還是漢字,較為方便,但在存儲英文時數(shù)量上有些損失。


            http://www.cnblogs.com/lichang1987/archive/2009/03/04/1403166.html

                     最近在公司里做項目,遇到一個問題,建的數(shù)據(jù)庫里的中文字符和音標顯示為亂碼,組里的人所有字符都用varchar表示,所以出現(xiàn)上訴問題,當改為Nvarchar后,問題得到解決。所以有必要把他們的區(qū)別再重新復習一遍。

                     char類型: 對英文(ASCII)字符占用1個字節(jié),對一個漢字占用2個字節(jié),CHAR存儲定長數(shù)據(jù)很方便,CHAR字段上的索引效率級高,比如定義char(10),那么不論你存儲的數(shù)據(jù)是否達到了10個字節(jié),都要占去10個字節(jié)的空間。因為是固定長度,所以速度效率高。 

                    Varchar類型:Varchar 的類型不以空格填滿,比如varchar(100),但它的值只是"qian",則它的值就是"qian"
            而char 不一樣,比如char(100),它的值是"qian",而實際上它在數(shù)據(jù)庫中是"qian "(qian后共有96個空格,就是把它填滿為100個字節(jié))。 

                    由于char是以固定長度的,所以它的速度會比varchar快得多!但程序處理起來要麻煩一點,要用trim之類的函數(shù)把兩邊的空格去掉!

                    VARCHAR存儲變長數(shù)據(jù),但存儲效率沒有CHAR高。如果一個字段可能的值是不固定長度的,我們只知道它不可能超過10個字符,把它定義為 VARCHAR(10)是最合算的。VARCHAR類型的實際長度是它的值的實際長度+1。為什么“+1”呢?這一個字節(jié)用于保存實際使用了多大的長度。

                    Nchar類型和Nvarchar類型是怎么一回事呢?為了與其他多種字符的轉換,如中文,音標等,對每個英文(ASCII)字符都占用2個字節(jié),對一個漢字也占用兩個字節(jié),所有的字符都占用2個字節(jié)。

            例如

            varchar(n):變長型字符數(shù)據(jù)類型,存儲最長長度為8,000 個字符。

            舉個例子:
            insert a select '木子a'
            --- 存儲長度為5個字節(jié),余下的3個字節(jié)全部釋放
            insert a select '木神易
            ----存儲長度為6個字節(jié),余下的2個字節(jié)全部釋放
            ---意思是varchar變長字符數(shù)據(jù)類型與存儲數(shù)據(jù)的實際長度是一致的

            nvarchar(n):可變長度 Unicode 數(shù)據(jù),其最大長度為 4,000 字符。
            字節(jié)的存儲大小是所輸入字符個數(shù)的兩倍,
            就是說它是雙字節(jié)來存儲數(shù)據(jù)的。
            如果存儲數(shù)據(jù)如果存在單字節(jié)時,它也是以雙字節(jié)來占用存儲空間的。

            varchar一般適用于英文和數(shù)字,Nvarchar適用中文和其他字符,其中N表示Unicode常量,可以解決多語言字符集之間的轉換問題


            posted on 2011-09-14 14:56 楊粼波 閱讀(1179) 評論(2)  編輯 收藏 引用 所屬分類: 網(wǎng)絡編程

            評論

            # re: nchar,char,varchar與nvarchar區(qū)別 2011-09-20 16:17 cheap lace front wigs

            這個問題確實很重要,看起來很簡單的東西,新手不知道,在創(chuàng)建的時候總是用一種固定的方法,有時候就會出問題  回復  更多評論   

            # re: nchar,char,varchar與nvarchar區(qū)別 2011-10-03 15:24 龍之騰98

            簡單的問題深藏著未知的深邃啊  回復  更多評論   

            少妇精品久久久一区二区三区 | 欧美日韩精品久久久久| 国产激情久久久久影院| 久久最新免费视频| 色综合久久久久综合体桃花网| 无码久久精品国产亚洲Av影片| 国产麻豆精品久久一二三| 欧美日韩成人精品久久久免费看 | 久久婷婷国产综合精品| 国产综合免费精品久久久| 久久精品国产AV一区二区三区| 久久99精品久久久久久动态图 | 亚洲AⅤ优女AV综合久久久| 99久久人妻无码精品系列 | 久久精品视频91| 久久偷看各类wc女厕嘘嘘| 久久精品亚洲男人的天堂| 狠色狠色狠狠色综合久久| av色综合久久天堂av色综合在| 久久精品国产一区二区 | 9191精品国产免费久久| 久久久无码精品亚洲日韩蜜臀浪潮| 国产精品激情综合久久| 久久久久久毛片免费播放| 久久精品国产亚洲AV香蕉| 久久AAAA片一区二区| 97久久精品午夜一区二区| 亚洲国产精品无码久久久蜜芽| 久久伊人五月天论坛| 国内精品久久久久久久久电影网| 精品久久久久久国产| 久久久久亚洲AV无码网站| 2021国产精品久久精品| 久久天天躁狠狠躁夜夜不卡| 国内精品久久久久久久亚洲| 一本久久a久久精品综合夜夜| 国产精品青草久久久久婷婷| 2021久久国自产拍精品| 国产亚洲欧美精品久久久| 久久香蕉综合色一综合色88| 品成人欧美大片久久国产欧美|