人妖在线一区,国产日韩欧美一区二区综合在线,国产啪精品视频网站免费,欧美内射深插日本少妇

新聞動態(tài)

C#連接ORACLE出現(xiàn)亂碼問題的解決方法

發(fā)布日期:2021-12-26 14:53 | 文章來源:CSDN

以前做過java項目,連接各種數(shù)據(jù)庫都得心應(yīng)手,最近接觸c#的一個項目,連接SqlServer數(shù)據(jù)庫倒也是很好用,但是遇到oracle數(shù)據(jù)庫就萎了,于是搜索好多資料,有使用oracle.datamanager.dataaccess的,有System.Data.OracleClient.OracleConnection的,也有System.Data.OleDb.OdbcConnection連接的,但前兩種方式都試了,依舊如此亂碼,于是就試試最后一種:

方法一

連接字符串:

"Provider=oraoledb.oracle;Data Source=(DESCRIPTION =(ADDRESS_LIST = (ADDRESS = (PROTOCOL = TCP)(HOST = 10.20.10.10)(PORT = 1521)))(CONNECT_DATA = (SID = orcl))) ;User Id=user;Password=user"

報錯:未注冊數(shù)據(jù)提供程序!

于是繼續(xù)搜索,網(wǎng)上說需要安裝oracle相關(guān)連接組件,這就很麻煩了,不可能所有機子都安裝這個組件

于是繼續(xù)找解決方法,最后發(fā)現(xiàn)以下連接是可以的,也就是在使用System.Data.OracleClient.OracleConnection時候,不再提示注冊程序之類的, 問題終于解決了,查詢結(jié)果也不亂碼!

連接字符串:

"Provider=MSDAORA.1;Data Source=(DESCRIPTION =(ADDRESS_LIST = (ADDRESS = (PROTOCOL = TCP)(HOST =
10.20.10.10
)(PORT = 1521)))(CONNECT_DATA = (SID = orcl))) ;User Id=lswen;Password=1169"

注意:Provider=MSDAORA.1; 而不是Provider=oraoledb.oracle;

方法二

1.打開注冊表:開始-運行-regedit

HKEY_LOCAL_MACHINE/SOFTWARE/ORACLE/KEY_OraDb11g_home1/OLEDB
在右側(cè)點鼠標右鍵--新建--字符串值--名稱改為:NLS_LANG 值設(shè)為:SIMPLIFIED CHINESE_CHINA.ZHS16GBK

2.我的電腦-屬性-高級系統(tǒng)設(shè)置-環(huán)境變量-在系統(tǒng)變量下方點擊新建--變量名:NLS_LANG 變量值: SIMPLIFIED CHINESE_CHINA.ZHS16GBK

方法三

make1828同學給出的解決方法

1:先查詢oralce的字符編碼:select userenv('language') from dual;

2:在環(huán)境變量中設(shè)置NLS_LANG變量:

3:配置連接字符串:

Provider=OraOLEDB.Oracle;User ID=***;Password=***;Data Source=(DESCRIPTION = (ADDRESS_LIST= (ADDRESS = (PROTOCOL = TCP)(HOST = ***)(PORT = 1521))) (CONNECT_DATA = (SERVICE_NAME = ORCL)))

4:安裝Oracle客戶端:(可自行網(wǎng)上搜索下載)

5:需要的可用下載一個PLSQL工具

可以到本站下載即可 https://www.jb51.net/softs/664139.html

方法四

最近我用程序讀取oracle數(shù)據(jù)庫中數(shù)據(jù)時發(fā)現(xiàn)中文全部是亂碼。于是我展開了一系列的辦法最終解決了此問題。

工作環(huán)境:服務(wù)器 windows 2003+ oracle。
服務(wù)器字符集 SIMPLIFIED CHINESE_CHINA.WE8DEC。
編程環(huán)境 VS2005,C#,PLSQL。

方案一:

利用System.Data.OracleClient.OracleConnection類訪問數(shù)據(jù)庫。

連接字符串:

"Data Source= (DESCRIPTION =(ADDRESS_LIST = (ADDRESS = (PROTOCOL = TCP)(HOST = 172.20.0.5)(PORT = 1521)))(CONNECT_DATA = (SID = DEV))) ;User Id=lswen;Password=1169"

將本地字符集改為與服務(wù)器相同。

打開注冊表regdit:

HKEY_LOCAL_MACHINE\SOFTWARE\ORACLE\HOMEO 中NLS_LANG改為: SIMPLIFIED CHINESE_CHINA.WE8DEC。

這個方法簡直就像噩夢,根本解決不了,網(wǎng)上有很多人發(fā)表用這種方法。答案是片面的,如果服務(wù)器的字符集是: ZHS16GBK那么此法就可以解決。字符集WE8DEC是西歐字符集本身包含的漢字就不多,之所以它允許用存入漢字是因為它將一個漢字拆分為兩個字節(jié)存儲方式,其他中文字符集的客戶端無法直接還原為一個中文。所以必須保持客戶端與服務(wù)器一致-----這網(wǎng)上看到的不知道自己的理解是否對。

方案一 失敗。

方案二 :

利用System.Data.OleDb.OdbcConnection類訪問數(shù)據(jù)庫。

連接字符串:

"Provider=MSDAORA.1;Data Source=(DESCRIPTION =(ADDRESS_LIST = (ADDRESS = (PROTOCOL = TCP)(HOST = 172.20.0.5)(PORT = 1521)))(CONNECT_DATA = (SID = DEV))) ;User Id=lswen;Password=1169"

將本地字符集改為與服務(wù)器相同,方法同方案一相同。
這一下問題終于解決了。

強調(diào)連接字符串因該使用Provider=MSDAORA.1; 不能使用Provider=oraoledb.oracle;

方案二 成功了。

總結(jié) :

不管是WE8DEC,還是其他一些西歐字符集都存在這樣的問題,用第二種方案應(yīng)該都可以解決。

版權(quán)聲明:本站文章來源標注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請保持原文完整并注明來源及原文鏈接。禁止復制或仿造本網(wǎng)站,禁止在非www.sddonglingsh.com所屬的服務(wù)器上建立鏡像,否則將依法追究法律責任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學習參考,不代表本站立場,如有內(nèi)容涉嫌侵權(quán),請聯(lián)系alex-e#qq.com處理。

實時開通

自選配置、實時開通

免備案

全球線路精選!

全天候客戶服務(wù)

7x24全年不間斷在線

專屬顧問服務(wù)

1對1客戶咨詢顧問

在線
客服

在線客服:7*24小時在線

客服
熱線

400-630-3752
7*24小時客服服務(wù)熱線

關(guān)注
微信

關(guān)注官方微信
頂部