使用C#通过Oracle.DataAccess连接Oracle,部署时需要注意版本问
平时我们开发使用的是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.NETbin2.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,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节点结束之后增加如下内容: (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- asp.net-web-api – webapi批处理和委托处理程序
- asp.net – 是否有可能检测到移动浏览器的GPS位置?
- asp.net-core – 在VS2017中为.NET CORE 2.0设置dotnet-wat
- asp.net-mvc – 为什么在Asp.net MVC 2中的子操作中不允许重
- WebApi ASP.NET身份Facebook登录
- asp.net – FormsAuthentication:是否安全?
- 什么是链接服务器的ASP.NET连接字符串格式?
- asp.net-mvc – 创建自定义RouteBase类
- asp.net-mvc – 当使用AutoMapper / AutoMapViewResult时如
- asp.net-mvc – ASP.NET MVC:获取所有控制器
- 在ASP.NET 4.5 WebForms中通过bundle.config和Bu
- asp.net-mvc – ASP.Net MVC路由到用户名
- asp-classic – 从fso对象创建ado记录集
- .net – 如何修复System.Data.Edm.EdmEntityType
- 如何在ASP.NET成员资格中访问UserId而不使用Memb
- ASP.NET MVC注定要取代Webforms吗?
- asp.net – 在ASCX自定义控件中放置CSS规则的位置
- 在Classic ASP中从ADODB调用参数化Oracle查询
- ASP.NET Core 新建项目(Windows) - ASP.NET Core
- asp.net – 天蓝色的动态子域