久久精品在这里_成人99免费视频_国产激情视频一区二区在线观看_国产伦精品一区二区三区免费 _亚洲午夜免费福利视频_色狠狠色狠狠综合_av在线综合网_91毛片在线观看_欧美视频一区二区在线观看_极品美女销魂一区二区三区免费_国产亚洲欧美激情_在线免费观看不卡av_日韩不卡一区二区三区_91精品国产麻豆国产自产在线_亚洲国产精品一区二区久久恐怖片_a4yy欧美一区二区三区


曙海教育集團(tuán)論壇開(kāi)發(fā)語(yǔ)言培訓(xùn)專區(qū)SQL Server數(shù)據(jù)庫(kù) → 國(guó)際化使用UTF-8造成數(shù)據(jù)庫(kù)MSSQL Server 2000/2005存儲(chǔ)亂碼的分析


  共有7764人關(guān)注過(guò)本帖樹(shù)形打印

主題:國(guó)際化使用UTF-8造成數(shù)據(jù)庫(kù)MSSQL Server 2000/2005存儲(chǔ)亂碼的分析

美女呀,離線,留言給我吧!
wangxinxin
  1樓 個(gè)性首頁(yè) | 博客 | 信息 | 搜索 | 郵箱 | 主頁(yè) | UC


加好友 發(fā)短信
等級(jí):青蜂俠 帖子:1393 積分:14038 威望:0 精華:0 注冊(cè):2010-11-12 11:08:23
國(guó)際化使用UTF-8造成數(shù)據(jù)庫(kù)MSSQL Server 2000/2005存儲(chǔ)亂碼的分析  發(fā)帖心情 Post By:2010-12-13 13:34:58

看了許多網(wǎng)上使用MSSQL Server 2000/2005使用UTF-8造成數(shù)據(jù)庫(kù)存儲(chǔ)亂碼的描述,也說(shuō)一下自己做的一個(gè)國(guó)際化項(xiàng)目的經(jīng)驗(yàn)。
這個(gè)項(xiàng)目描述:
架構(gòu):VC++的ATL Server進(jìn)行開(kāi)發(fā);
頁(yè)面:web頁(yè)面是UTF-8編碼,CodePage=65001;
應(yīng)用服務(wù)器程序:編譯好的dll是Unicode編碼;
操作系統(tǒng):中文Windows 2003 Server;
數(shù)據(jù)庫(kù)聯(lián)接方式:OLEDB
數(shù)據(jù)庫(kù):中文MSSQL Sever2005,顯示Codepage=936,
字段都是支持Unicode的nchar,nvarcha,nText;
SELECT COLLATIONPROPERTY('Chinese_PRC_Stroke_CI_AI', 'CodePage')
936
________________________________________________

發(fā)現(xiàn)從Web頁(yè)面提交的數(shù)據(jù)到數(shù)據(jù)后查詢總是亂碼,經(jīng)過(guò)檢查,發(fā)現(xiàn)保存的數(shù)據(jù)直接就是是UTF-8編碼,其CodePage=65001,而數(shù)據(jù)默認(rèn)顯示支持的Unicode語(yǔ)言版本Codepage=936(即是簡(jiǎn)體中文),所以數(shù)據(jù)查詢的就是亂碼,想過(guò)兩種方案:
1,懷疑是數(shù)據(jù)時(shí)UTF-8編碼,而SQLServer是UCS-2 版本,相通過(guò)UTF-8-〉UCS-2轉(zhuǎn)換,發(fā)現(xiàn)還是行不通,仍然亂碼,此路不通;
2,
搜索了網(wǎng)絡(luò)發(fā)現(xiàn)并沒(méi)有現(xiàn)成的例子,經(jīng)過(guò)測(cè)試中文系統(tǒng)使用Web頁(yè)面為GB2312編碼提交的數(shù)據(jù)到數(shù)據(jù)很正常,基于Windows2003是支持
Unicode(UCS-2),排除操作系統(tǒng)的問(wèn)題,這個(gè)過(guò)程經(jīng)過(guò)分析可以這么理解:936(Web頁(yè)面編碼GB2312)-〉Unicode(應(yīng)用服務(wù)
器端)-〉Unicode(數(shù)據(jù)庫(kù)OLEDB傳輸)-〉UCS-2(數(shù)據(jù)庫(kù))-〉自動(dòng)轉(zhuǎn)化為936(Unicode簡(jiǎn)體中文語(yǔ)言版本),而使用UTF-8
的Web頁(yè)面這個(gè)過(guò)程就是:65001(Web頁(yè)面編碼UTF-8)-〉Unicode(應(yīng)用服務(wù)器端)-〉Unicode(數(shù)據(jù)庫(kù)OLEDB傳輸)-〉
UCS-2(數(shù)據(jù)庫(kù))-〉自動(dòng)轉(zhuǎn)化為936(Unicode簡(jiǎn)體中文語(yǔ)言版本),所以最后的使用數(shù)據(jù)分析查詢器看到的就是亂碼,最后確定的方案就是兩種手
段:一是更改數(shù)據(jù)查詢分析器的Codepage為65001,很顯然當(dāng)前的SQLServer沒(méi)有這個(gè)功能(沒(méi)找到?知道的告訴我);二是將前端的UTF
-8轉(zhuǎn)為GB2312編碼,很顯然這個(gè)最后成功了,這個(gè)過(guò)程程序還是保留了所有的多語(yǔ)言的特性,一位UTF-8-〉GB2312,這個(gè)過(guò)程是無(wú)損的(新的
驗(yàn)證會(huì)出現(xiàn)部分方塊無(wú)法顯示),因?yàn)槭荱TF-8->Unicode->GB2312.
總結(jié):
1,MSSQL
Server不支持UTF-8(Codepage=65001)直接顯示,數(shù)據(jù)庫(kù)查詢的顯示數(shù)據(jù)使用默認(rèn)的Codepage,如簡(jiǎn)體中文版就是936,繁
體中文是950,韓文949等,因此從使用的Web頁(yè)面UTF-8提交的數(shù)據(jù)自動(dòng)轉(zhuǎn)換為所用的Codepage顯示,因此就是亂碼,這個(gè)有待MS
SQL
Server進(jìn)一步發(fā)展,因?yàn)楝F(xiàn)在Oracle和MySQL是可以支持直接UTF-8存儲(chǔ)顯示,國(guó)際化時(shí)請(qǐng)先將數(shù)據(jù)由UTF-8編碼轉(zhuǎn)化為MSSQL數(shù)據(jù)
庫(kù)默認(rèn)的編碼,讀寫出來(lái)這個(gè)過(guò)程著相反進(jìn)行轉(zhuǎn)化,這個(gè)過(guò)程看起來(lái)會(huì)因?yàn)檗D(zhuǎn)化過(guò)程影響處理速度(抉擇于國(guó)際化);
2,ASP/ASPX/JSP/PHP使用MSSQL Server編程支持UTF-8都會(huì)面臨這樣的問(wèn)題,可以看看MSDN有關(guān)這個(gè)方面的解釋
補(bǔ)充:根據(jù)測(cè)試和MSDN分析,將UTF-8轉(zhuǎn)化為GB2312并不是很好的方案,這樣會(huì)使包含韓文、阿拉伯文等等,這些都會(huì)變成問(wèn)號(hào),所以整個(gè)過(guò)程并不是很繁瑣,簡(jiǎn)化一下:
寫數(shù)據(jù)庫(kù):瀏覽器表單提交數(shù)據(jù)(UTF-8)(ANSI編碼)-〉應(yīng)用服務(wù)器端程序(進(jìn)行UTF-8-〉Unicode)-〉MS SQL Server(自動(dòng)轉(zhuǎn)化為字符集936編碼顯示內(nèi)容,但數(shù)據(jù)肯定是Unicode方式存儲(chǔ)的);
讀數(shù)據(jù)庫(kù):MS SQL Server(936 - Unicode)-〉應(yīng)用服務(wù)器端程序(進(jìn)行Unicode-〉UTF-8)-〉瀏覽器顯示
注意:其他條件設(shè)置不變
 
兩個(gè)使用的函數(shù):
1,UTF8轉(zhuǎn)化為Unicode,inline為了編譯后更快運(yùn)行,老用到了,返回字符串為了使用鏈?zhǔn)奖磉_(dá)式
inline WCHAR  *UTF8ToUnicode(const char *str) throw()
 {
  int i = MultiByteToWideChar(CP_UTF8,MB_ERR_INVALID_CHARS,str,-1,NULL,0);        
  WCHAR   *strUnicode=new   WCHAR[i];        
  MultiByteToWideChar(CP_UTF8,MB_ERR_INVALID_CHARS,str,-1,strUnicode,i);
  return strUnicode;
  delete []strUnicode;
 }
一定要返回WCHAR 或wchar_t類型,否則有些字符就會(huì)變成“?”,Unicode(UCS-2)是2個(gè)字節(jié)寬
 
2,Unicode轉(zhuǎn)化為UTF8,inline同上意義
inline char *UnicodeToUTF8(const WCHAR* pText) throw()
 {
  int i= WideCharToMultiByte(CP_UTF8

支持(0中立(0反對(duì)(0單帖管理 | 引用 | 回復(fù) 回到頂部

返回版面帖子列表

國(guó)際化使用UTF-8造成數(shù)據(jù)庫(kù)MSSQL Server 2000/2005存儲(chǔ)亂碼的分析








簽名
久久精品在这里_成人99免费视频_国产激情视频一区二区在线观看_国产伦精品一区二区三区免费 _亚洲午夜免费福利视频_色狠狠色狠狠综合_av在线综合网_91毛片在线观看_欧美视频一区二区在线观看_极品美女销魂一区二区三区免费_国产亚洲欧美激情_在线免费观看不卡av_日韩不卡一区二区三区_91精品国产麻豆国产自产在线_亚洲国产精品一区二区久久恐怖片_a4yy欧美一区二区三区
欧美下载看逼逼| 欧美日韩国产乱码电影| 五月天一区二区| 国产精品美女视频| 久久综合精品国产一区二区三区| 欧美男同性恋视频网站| 亚洲免费在线精品一区| 国模精品娜娜一二三区| 国产伦精品一区二区三区四区视频 | 国产伦精品一区二区三区高清版| 444亚洲人体| 国模精品娜娜一二三区| 欧美一区二区视频在线| 亚洲一区二区三区精品在线观看| 色哟哟一区二区三区| 在线观看日产精品| 色94色欧美sute亚洲13| 欧美中文字幕一区| 欧美日韩一卡二卡三卡| 欧美一区二区三区免费观看视频| 色偷偷88欧美精品久久久| 在线精品视频免费播放| 色综合视频一区二区三区高清| 久久精品日韩| 成人国产一区二区三区精品| 久久精品国产亚洲一区二区三区| 天堂一区二区在线| 国产精品久久久久影院老司 | 日本在线观看一区二区三区| 91欧美一区二区| 国产精品一区二区在线观看不卡 | 国产成人亚洲欧美| 成人av资源在线| 国产福利一区在线观看| 日韩高清欧美激情| 亚欧色一区w666天堂| 一区二区三区欧美亚洲| 亚洲日本va午夜在线影院| 国产精品久久影院| 日本一区二区三区免费看| 99久久精品99国产精品| 91九色最新地址| 91视频观看视频| 国产在线视频不卡二| 蜜臀国产一区二区三区在线播放| 亚洲欧美精品午睡沙发| 国产精品乱码久久久久久| 一区二区视频免费在线观看| 亚洲品质自拍视频网站| 亚洲国产成人tv| 极品尤物av久久免费看| 国产一区二区成人久久免费影院| 99久久久国产精品免费蜜臀| 成人ar影院免费观看视频| 黄色一区三区| 亚洲国产激情一区二区三区| 一区二区三区av| 日韩欧美资源站| 国产一区喷水| 美日韩一区二区| 曰韩精品一区二区| 欧美一级午夜免费电影| 国产亚洲一区二区三区| 亚洲欧美欧美一区二区三区| 欧美精品三级日韩久久| 中日韩av电影| 狠狠色狠狠色综合| 欧洲亚洲精品在线| 在线不卡a资源高清| 久久一区二区视频| 日韩精品免费视频人成| youjizz久久| 一区二区三区四区在线视频| 亚洲精品一区二区三区精华液| 亚洲人成小说网站色在线| 天堂精品中文字幕在线| 久久婷婷开心| 亚洲欧洲av另类| 国产成人亚洲精品青草天美| 日本高清视频一区二区| 亚洲人成在线播放网站岛国| 久久99国产乱子伦精品免费| 久久青青草原| 亚洲欧美激情在线| 99久久久精品免费观看国产蜜| 欧美日韩黄色一区二区| 日本成人超碰在线观看| 国产.欧美.日韩| 精品少妇一区二区三区视频免付费 | 视频在线观看成人| 亚洲免费电影在线| 91麻豆精东视频| 欧美日韩国产经典色站一区二区三区| 国产成人免费在线视频| 91精品国产一区二区三区香蕉| 日韩电影一二三区| 亚洲观看高清完整版在线观看| 正在播放一区二区三区| 亚洲欧美激情在线| 91在线精品一区二区三区| 久久综合久久综合久久综合| 成人精品一区二区三区四区| 国产iv一区二区三区| 精品国产凹凸成av人网站| 国产精品一区二区三区免费 | 成人18视频日本| 26uuu亚洲综合色欧美| 99re视频在线| 一区二区三区在线观看欧美| 亚洲一区二区三区欧美| 黄色小说综合网站| 国产视频一区在线观看| 欧美一进一出视频| 福利一区在线观看| 日本一二三不卡| 欧美日韩高清一区二区三区| 粉嫩高清一区二区三区精品视频| 国产精品美女久久久久久久久| 视频一区国产精品| 91小宝寻花一区二区三区| 7777精品伊人久久久大香线蕉的 | 欧美羞羞免费网站| 91蜜桃免费观看视频| 日本亚洲三级在线| 一区二区三区久久久| 久久美女高清视频| 一区二区在线不卡| 欧美精品一区二区三区在线四季| 亚洲精品一区二区三| 972aa.com艺术欧美| 青青草成人在线观看| 亚洲麻豆国产自偷在线| 国产三级欧美三级| 免费国产一区二区| 天天综合天天综合色| 亚洲一区二区在线视频| 亚洲国产精品高清| 欧美tk—视频vk| 91成人免费网站| 婷婷四月色综合| 久久久com| 国产精品天天看| 久久综合五月天婷婷伊人| 精品美女被调教视频大全网站| 国产高清在线一区二区| 99久久精品国产网站| 国产伦精品一区二区三区照片91| 99re66热这里只有精品3直播| 舔着乳尖日韩一区| 国产一区在线精品| 久久成人免费电影| 国产suv精品一区二区三区| 天使萌一区二区三区免费观看| 国产亚洲午夜高清国产拍精品| 日日摸夜夜添夜夜添亚洲女人| av一本久道久久综合久久鬼色| 婷婷久久青草热一区二区| 国产视频亚洲色图| 精品亚洲欧美一区| 日韩在线电影一区| 欧美国产成人精品| 成人精品小蝌蚪| 色偷偷久久人人79超碰人人澡| 亚洲欧美偷拍卡通变态| 99免费精品在线观看| 欧美性猛交xxxx黑人交| 夜色激情一区二区| 久久香蕉综合色| 国产精品美女久久久久aⅴ国产馆| 国产999精品久久久久久| 色综合久久天天| 亚洲综合色噜噜狠狠| 麻豆成人在线播放| 国产精品视频免费| 99久久精品久久久久久清纯| 欧美疯狂性受xxxxx喷水图片| 亚洲第一福利一区| 日本一区二区三区精品视频| 亚洲制服丝袜一区| 亚洲一区二区三区精品在线观看| 亚洲成人一区二区在线观看| 亚洲mv在线看| 久久国产欧美日韩精品| 欧美精品在欧美一区二区少妇| 国产在线精品一区在线观看麻豆| 欧美日韩一级二级| 不卡高清视频专区| 国产午夜精品一区二区| 91久久精品一区二区别| √…a在线天堂一区| 亚洲永久一区二区三区在线| 热久久一区二区| 精品少妇一区二区三区免费观看| 99久久99久久综合| 亚洲丝袜美腿综合| 欧美中文字幕不卡| www.亚洲色图.com| 亚洲综合男人的天堂| 欧美三级欧美一级| 91视视频在线观看入口直接观看www |