使用Oracle.DataClient时,提供程序与Oracle客户端错误的版本不兼容

时间:2009-08-09 04:39:36

标签: visual-studio-2008 oracle odp.net

我正在使用Visual Studio 2008 Express Edition,我正在尝试使用Oracle.DataClient开发一个小应用程序。 当我尝试连接到目标系统中的数据库时,我收到了上述错误。

我已经为Oracle 10gR2添加了对Oracle ODP.net提供程序的引用,并且在目标计算机中我安装了Oracle 10gR2数据库的副本。尽管如此,我收到了错误。 在发布之前,我在SO上阅读了this post,并且我已经安装了即时客户端,错误仍然存​​在。 下面是完整的错误堆栈。

************** Exception Text **************
System.TypeInitializationException: The type initializer for 'Oracle.DataAccess.Client.OracleConnection' threw an exception. ---> Oracle.DataAccess.Client.OracleException The provider is not compatible with the version of Oracle client    at Oracle.DataAccess.Client.OracleInit.Initialize()
   at Oracle.DataAccess.Client.OracleConnection..cctor()
   --- End of inner exception stack trace ---
   at Oracle.DataAccess.Client.OracleConnection..ctor(String connectionString)
   at Employees1.frmLogin.oralogin()
   at Employees1.frmLogin.btnTest_Click(Object sender, EventArgs e)
   at System.Windows.Forms.Control.OnClick(EventArgs e)
   at System.Windows.Forms.Button.OnClick(EventArgs e)
   at System.Windows.Forms.Button.OnMouseUp(MouseEventArgs mevent)
   at System.Windows.Forms.Control.WmMouseUp(Message& m, MouseButtons button, Int32 clicks)
   at System.Windows.Forms.Control.WndProc(Message& m)
   at System.Windows.Forms.ButtonBase.WndProc(Message& m)
   at System.Windows.Forms.Button.WndProc(Message& m)
   at System.Windows.Forms.Control.ControlNativeWindow.OnMessage(Message& m)
   at System.Windows.Forms.Control.ControlNativeWindow.WndProc(Message& m)
   at System.Windows.Forms.NativeWindow.Callback(IntPtr hWnd, Int32 msg, IntPtr wparam, IntPtr lparam)


************** Loaded Assemblies **************
mscorlib
    Assembly Version: 2.0.0.0
    Win32 Version: 2.0.50727.42 (RTM.050727-4200)
    CodeBase: file:///C:/WINDOWS/Microsoft.NET/Framework/v2.0.50727/mscorlib.dll
----------------------------------------
API Data Conversion Assistant
    Assembly Version: 0.0.0.1
    Win32 Version: 0.0.0.1
    CodeBase: file:///C:/Documents%20and%20Settings/3i/My%20Documents/My%20Dropbox/Sathya's%20dropbox/VisualStudio%20Releases/APIDataconversion/Application%20Files/API%20Data%20Conversion%20Assistant_0_0_0_3/API%20Data%20Conversion%20Assistant.exe
----------------------------------------
System.Windows.Forms
    Assembly Version: 2.0.0.0
    Win32 Version: 2.0.50727.42 (RTM.050727-4200)
    CodeBase: file:///C:/WINDOWS/assembly/GAC_MSIL/System.Windows.Forms/2.0.0.0__b77a5c561934e089/System.Windows.Forms.dll
----------------------------------------
System
    Assembly Version: 2.0.0.0
    Win32 Version: 2.0.50727.42 (RTM.050727-4200)
    CodeBase: file:///C:/WINDOWS/assembly/GAC_MSIL/System/2.0.0.0__b77a5c561934e089/System.dll
----------------------------------------
System.Drawing
    Assembly Version: 2.0.0.0
    Win32 Version: 2.0.50727.42 (RTM.050727-4200)
    CodeBase: file:///C:/WINDOWS/assembly/GAC_MSIL/System.Drawing/2.0.0.0__b03f5f7f11d50a3a/System.Drawing.dll
----------------------------------------
Oracle.DataAccess
    Assembly Version: 2.102.2.20
    Win32 Version: 2.102.2.20

我在开发应用程序的机器上安装了Oracle 11g,它在那里工作正常,但在目标机器上,我收到了这个错误。 任何输入都将受到赞赏。

PS:如上所述,引用的Oracle.DataClient.dll文件版本对应10gR2,而不是11g。

5 个答案:

答案 0 :(得分:17)

我一直在研究这个问题,你只需要从同一个下载版本的ODP.Net中获取所有相应的DLL,并将它们放在与Exe文件相同的文件夹中,因为ODP.Net很挑剔关于不混合版本号,这是你看到的问题(或者oci.dll完全丢失,在这种情况下它会产生同样的错误)。

我在这里解释了如何执行此操作:http://splinter.com.au/using-the-new-odpnet-to-access-oracle-from-c 这是它的要点:

答案 1 :(得分:1)

您是否已使用客户端系统上的ODBC管理员创建并成功测试了连接?

9i和10g客户端中存在针对权限问题的修补程序导致此错误。如果您的版本是10.2.0.1,则可能需要升级到10.2.0.3才能解决此问题。

答案 2 :(得分:0)

我已经使我的应用程序使用Ole DB(System.Data.Oledb命名空间)连接,并且它工作正常。考虑到应用程序只是调用Oracle SP的前端,并且没有返回值,我想这种方法是可以接受的,因为在我试图找到这个问题的解决方案的2天内我可以完成很多应用程序的更多开发。 我仍然愿意接受答案,因为我可以从未来的任何此类应用中犯下的错误中吸取教训。

答案 3 :(得分:0)

我遇到了同样的问题。如果您的计算机上安装了11g客户端,则需要使用11g ODP.Net DLL。我必须完全卸载所有内容,然后安装11g客户端,然后安装11g ODP.NET驱动程序。驱动程序安装在GAC中,这有点痛苦。

*请注意,我的DBA理解是,只有在您不必连接任何低于9i的版本时才能使用

我们也必须在我们的服务器上执行此操作。

HTH

答案 4 :(得分:0)

即使在安装了适当的Oracle Client版本之后,我们也必须检查服务器中安装了哪个.Net Framewark,ODP.Net支持.Net Framework 3.5至4.5.2.。

相关问题