C#操作American_America.US7ASCII编码的Oracle数据库出
现乱码的问题。
最近⼀个项⽬,需要连接Oracle数据库,
使⽤Oracle.ManagedDataAccess库连接,出现中⽂乱码,
排查发现,Oracle服务端是采⽤American_America.US7ASCII编码,再Oracle.ManagedDataAccess库中未到⽀持中⽂编码的格式或属性(不确定是否⽀持英⽂编码)
尝试解决⽅法:更换为使⽤System.Data.OleDb连接数据库
ConnectionString= "Provider=OraOLEDB.Oracle;Data Source=(DESCRIPTION =(ADDRESS_LIST = (ADDRESS = (PROTOCOL = TCP)(HOST = x)(PORT = 1521)))(CONNECT_DATA = (SID = xxx))) ;User Id=xxx;Password=xxx";
运⾏报错:未在本地计算机上注册“OraOLEDB.Oracle”提供程序。
解决⽅法:
安装ODAC
1.到Oracle官⽅⽹站下载ODAC安装包。在⽹页上到你要的版本。我下载的是ODAC112040Xcopy_64bit.zip
2.解压缩到D:\ODAC112040Xcopy_64bit,然后打开cmd,进⼊到这个⽂件夹。
3.安装ODAC
在cmd中运⾏install.bat批处理⽂件:输⼊"install.bat all D:\OracleClient ODAC"
“all”是安装全部,“D:\OracleClient”是安装⽬录  "ODAC" 是⽤于写注册表的 ORACLE HOME NAME
4. 设置环境变量
ORACLE_HOME=D:\OracleClient
NLS_LANG=American_America.US7ASCII
PATH=%ORACLE_HOME%;%ORACLE_HOME%\bin;
5. 根据需要配置a⽂件
如果要⽤组件访问Oracle数据库,那么就要根据需要配置a⽂件,并存放于%ORACLE_HOME%\network\admin⽬录下。
以下a⽂件格式如下,供参考:
ORA =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.26.231)(PORT = 1521))
)
(CONNECT_DATA =
(SERVICE_NAME = ora)
为什么oracle网站进不去
)
卸载ODAC的⽅法
⽤cmd进⼊到ODAC的安装路径下,然后运⾏该路径下的uninstall.bat批处理⽂件。这⾥也是要注意参数的运⽤。若要卸载掉所有组件,可以这样:
uninstall.bat all ODAC
或者
uninstall.bat all D:\OracleClient
⼿动删除掉安装⽬录,并把之前添加的环境变量也⼀并删除即可
(PS:摘⾃百度经验,并结合⾃⼰实际情况有所改动)

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。