使用C#通过Oracle.DataAccess连接Oracle,部署时需要注意版本问题
来源:互联网 发布:python 求第n个质数 编辑:程序博客网 时间:2024/05/19 12:40
平时我们开发使用的是32位的PC机,所以安装的也是Oracle32位的客户端。但是一般服务器都是64位的,安装的也是64位的Oracle客户端,如果要部署使用Oracle.DataAccess连接Oracle的应用程序时,可能会遇到版本上的问题。
主要版本问题有两种,一种是32位版和64位版的问题,如果我们开发出来的应用是32位的,那么就必须使用32位的客户端,如果是64位的应用程序当然对应64位的客户端。这里需要注意:在64位的环境中使用VS开发Web程序,其运行的Web服务“WebDev.WebServer.exe”是32位的,所以如果要调试64位的Oracle连接程序,最好是部署到IIS中,使用IIS来连接Oracle数据库。
另一个版本问题是Oracle.DataAccess的版本号问题,我的本机就是32位的XP,安装了Oracle11gR2客户端后,在安装目录下的ODP.NET\bin\2.x目录中可以找到Oracle.DataAccess.dll文件,可以看到其版本号是:2.112.1.2。所以我开发出来的程序,引用的也是这个版本的库。
但是在64位下的Oracle.DataAccess.dll却不一样,安装后的版本是2.112.1.0,如图是Windows2008X64上的Oracle.DataAccess.dll。
现在把开发环境的程序发布部署到服务器上,就会抛出异常
未能加载文件或程序集“Oracle.DataAccess, Version=2.112.1.2, Culture=neutral, PublicKeyToken=89b483f429c47342”或它的某一个依赖项。
或者是
Could not load file or assembly 'Oracle.DataAccess, Version=2.112.1.2, Culture=neutral, PublicKeyToken=89b483f429c47342' or one of its dependencies. An attempt was made to load a program with an incorrect format之类的话。
总之就是找不到对应的程序集。显然,这里系统找的是2.112.1.2版本的Oracle.DataAccess,而服务器上只有2.112.1.0版本的,所以才报错,解决办法就是在web.config中修改,在configSections节点结束之后增加如下内容:
<runtime>
<assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
<dependentAssembly>
<assemblyIdentity name="Oracle.DataAccess"
publicKeyToken="89B483F429C47342"
culture="neutral" />
<bindingRedirect
oldVersion="2.112.1.2"
newVersion="2.112.1.0"/>
</dependentAssembly>
</assemblyBinding>
</runtime>
- 使用C#通过Oracle.DataAccess连接Oracle,部署时需要注意版本问题
- C#用Oracle.DataAccess中连接Oracle要注意版本问题!
- C#用Oracle.DataAccess中连接Oracle要注意版本问题!
- 使用C# 连接不同版本的Oracle.DataAccess
- 使用C# 连接不同版本的Oracle.DataAccess
- C# 使用Oracle.DataAccess.dll注意事项
- C# 使用Oracle.DataAccess.dll注意事项
- .NET中使用ODP(Oracle.DataAccess)连接Oracle数据时出现的异常
- 使用oracle数据库需要注意的问题
- 使用Oracle SQL trace时需要注意的问题
- asp.net及IIS使用Oracle.DataAccess连接Oracle11g总结
- VS通过Oracle驱动连接数据库,对图片进行存取操作(Oracle.DataAccess.Client.dll)
- 使用Rancher部署K8S时需要注意的软件版本问题
- c#通过Oracle.DataAccess访问Oracle数据库的性能及访问方式小结
- “Oracle.DataAccess.Client.OracleException: 提供程序与此版本的 Oracle 客户机不兼容”问题的解决方案
- WebService部署时“需要ORACLE客户端软件8.1.7或更高版本”等问题的解决
- Oracle使用并行建索引需要注意的问题
- [DevExpress使用随笔]之Oracle.DataAccess
- 新浪出输入法了,深蓝词库转换更新到1.3.1——增加对新浪拼音输入法的支持
- 在.Net中使用Oracle的表类型和对象类型
- 在64位的环境中使用VS建立Web项目进行Oracle连接需要注意WebDev是32位的
- Linux+Oracle环境下如何将A服务器上的数据库备份还原到B服务器
- 使用C#读取dbf行情文件
- 使用C#通过Oracle.DataAccess连接Oracle,部署时需要注意版本问题
- 动态Linq的逻辑与和逻辑或的条件查询
- Oracle数据库需要修改默认的Profiles,避免用户密码过期
- 苹果开发者帐号申请流程-个人版
- 在企业应用开发中遵循开源协议
- NHibernate中对同一个对象的Lazyload要设置一致
- 如何将数据库从SQL Server迁移到MySQL
- 深蓝词库转换1.5发布
- 对象的继承关系在数据库中的实现方式和PowerDesigner设计