关于VS2008与一些数据源配置的问题

8月 20th, 2009 | Posted by | Filed under 数据库

本文内容遵从CC版权协议, 可以随意转载, 但必须以超链接形式标明文章原始出处和作者信息及版权声明
网址: http://www.penglixun.com/tech/database/vs2008_data_source_config_problem.html

Oracle Developer Tools For .Net (ODT.NET) 和 SQL Server 的数据源一直有些诡异的问题困扰我很久,这几天下了狠心把它们搞定,最终搞定了,并且发现问题的原因是非常简单的。 

首先是ODT.NET的问题,装好ODT以后,在VS2008中配置数据源,总是提示找不到可用的.NET应用程序,这不扯淡么,刚装好,并且在程序中using Oracle.Client是正确的,可以连接数据库的。

网上查了一些资料,全是扯淡,最后只能上OTN了,用灵格斯悲剧的看着老外用英文讨论,终于有个老外貌似解决了,他说是C:\Windows\Microsoft.NET\Framework64\v2.0.50727\CONFIG下的machine.config文件问题,因为

<add name=”Oracle Data Provider for .NET” invariant=”Oracle.DataAccess.Client” description=”Oracle Data Provider for .NET” type=”Oracle.DataAccess.Client.OracleClientFactory, Oracle.DataAccess, Version=2.111.6.0, Culture=neutral, PublicKeyToken=89b483f429c47342″ />
这一列的问题。灰色标出来的就是问题所在,因为装ODT.NET先得装Oracle Client,但是Oracle Client中也有个Provider,版本是2.111.6.0,装了ODT.NET之后,ODAC升级到2.111.6.20了,于是只要把灰色部门改成2.111.6.20,一切都好了,在这个文件中出现的所有关于Oracle Provider的都可以把2.111.6.0改成2.111.6.20,因为全部都升级了。

同时,C:\Windows\Microsoft.NET\Framework\v2.0.50727\CONFIG中的machine.config文件也最好改一下,我是X64系统,所以改Framework64目录就行了,如果是X86系统那就是改Framework目录,不过最好都要修改,这样万无一失。

我改过之后,VS跑起来了。

VS2008 ODT.NET

然后是SQL Server数据源的问题,连接总提示SQL Server没有打开远程连接,怎么可能?我明明打开了,在服务器上都可以连接。

后来突然意识到,在服务器上登录SQL Server数据库引擎时,发现服务器名里面是“VM-WIN2003\VM_WIN2003_MSSQL”,然后在VS中配置数据源时,自动搜索总是显示的服务器名是“VM-WIN2003”,感觉不对,重新写成“VM-WIN2003\VM_WIN2003_MSSQL”,终于在数据库列表中显示出了数据库中的数据库。

原来是个这么简单的问题!

VS2008 ODT.NET

目前还没有任何评论.