最近为使用Oracle11G数据库做个快速开发的小程序,使用64位Win2008+Vs2012环境,结果碰壁连环,幸好不算太笨,终于解决了,特记录一下。

测试环境: Oracle11g (11.2.0.3_64bit)安装在64位Win2008上,同机安装Vs2012,C#语言。

在项目引用system.data.oracleclient后,提示:Ms仅在.net framework 4尚支持system.data.oracleclient,今后的版本将不再提供这个组件了。

于是想改用Oracle提供的组件。

匆忙到Oracle官网下载了ODAC 11.2 Release 4 (11.2.0.3.0) ,32位和64位的都下了,很想当然地就安装了64位的ODP.Net,结果vs2012里的server explore里添加数据库连接时,根本不出现Oracle提供的组件选项。仔细看了一下,release 说明,只支持到VS2010,白忙了!

不死心,再下ODAC 11.2 Release 5 (11.2.0.3.20),32位和64位的都下了,爬网,网友说Vs2012是32位的,就安装了32位的ODP.Net,结果vs2012里的server explore里添加数据库连接时,出现Oracle提供的组件选项,心中一喜,有门。可是输入参数后报错:" Ora-12560:TNS:... " 。 按错误号检查了数据库服务、监听、TNSname等,似乎没有错。另外这个组件的界面也乖乖的,输入连接的验证用户名(小写)后,再输入密码,用户名就变成大写字母了的,让人不放心。

继续爬网,看到网友“安裝ODAC 11.2 Release 5後Visual Studio無法使用Oracle資料來源”一文,有些启发。但感觉问题还是出在安装程序做了坏事,破坏了原来能用的TNSNAME设置。当然,删除老版本是对的。

为测地删除我电脑上已安装的ODAC 11.2 Release 5,干脆再下载了最新版的ODAC 11.2.0.3.60 beta,然后先删除了ODAC 11.2 Release 5,再安装ODAC 11.2.0.3.60 beta,安装过程中还提示连接串参数了,心想终于快天亮了。安装顺利,Vs2012里添加连接,出现的界面也正常了(不象release 5那个怪了),输入参数,点击“测试连接”,依旧报错:" Ora-12560:TNS:... " 。

幸好检查下,lsnrctl service, 发现只有一个服务在听,缺少了2个实例(我的电脑上安装了2个不同的数据库实例NFD和ORCL)的TCP侦听,但是又不想用网友的办法手工修改machine.config的DbProviderFatories,于是启动 Net Configuration Assistant重新配置了一下,监听和本地命名,再重启了一下2个实例的服务和Listener服务,再看lsnrctl service,正常了,如下:

C:\Users\zyc>lsnrctl services

LSNRCTL for 64-bit Windows: Version 11.2.0.3.0 - Production on 16-7月 -2013 11:0
1:49

Copyright (c) 1991, 2011, Oracle.  All rights reserved.

正在连接到 (DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=zycBackupSvr)(PORT=1521)))
服务摘要..
服务 "CLRExtProc" 包含 1 个实例。
  实例 "CLRExtProc", 状态 UNKNOWN, 包含此服务的 1 个处理程序...
    处理程序:
      "DEDICATED" 已建立:0 已被拒绝:0
         LOCAL SERVER
服务 "nfd" 包含 1 个实例。
  实例 "nfd", 状态 READY, 包含此服务的 1 个处理程序...
    处理程序:
      "DEDICATED" 已建立:0 已拒绝:0 状态:ready
         LOCAL SERVER
服务 "nfdXDB" 包含 1 个实例。
  实例 "nfd", 状态 READY, 包含此服务的 1 个处理程序...
    处理程序:
      "D000" 已建立:0 已被拒绝:0 当前: 0 最大: 1022 状态: ready
         DISPATCHER <machine: ZYCBACKUPSVR, pid: 4988>
         (ADDRESS=(PROTOCOL=tcp)(HOST=zycBackupSvr)(PORT=44919))
服务 "orcl" 包含 1 个实例。
  实例 "orcl", 状态 READY, 包含此服务的 1 个处理程序...
    处理程序:
      "DEDICATED" 已建立:1 已拒绝:0 状态:ready
         LOCAL SERVER
服务 "orclXDB" 包含 1 个实例。
  实例 "orcl", 状态 READY, 包含此服务的 1 个处理程序...
    处理程序:
      "D000" 已建立:0 已被拒绝:0 当前: 0 最大: 1022 状态: ready
         DISPATCHER <machine: ZYCBACKUPSVR, pid: 4964>
         (ADDRESS=(PROTOCOL=tcp)(HOST=zycBackupSvr)(PORT=44968))
命令执行成功

就这样,在vs2012里,数量添加了Oracle数据库连接,打开了久违的Db。

[置顶] 64位Win2008_VS2012使用ODP.NET遭遇问题和解决办法的更多相关文章

  1. 64位Win2008_VS2012使用ODP.NET遭遇问题和解决办法

    原文地址:64位Win2008_VS2012使用ODP.NET遭遇问题和解决办法 最近为使用Oracle11G数据库做个快速开发的小程序,使用64位Win2008+Vs2012环境,结果碰壁连环,幸好 ...

  2. 64位Windows7升级IE11后无法启动的解决办法

    1.控制面板\网络和 Internet\Internet选项 2.在高级选项卡的“安全”组配置

  3. Ubuntu(64位)编译Android源码常见错误解决办法

    2013年07月10日 14:47:27 阅读数:1239 错误: /usr/include/gnu/stubs.h:7:27: error: gnu/stubs-32.h: No such file ...

  4. 64位 SQL Server2008链接访问Oracle 过程汇总解决方法记录

    64位 SQL Server2008链接访问Oracle 过程汇总解决方法记录 经过几天不停的网上找资料,实验,终于联通了. 环境:系统:win 2008 ,SqlServer2008 R2, 连接O ...

  5. 64位系统使用Access 数据库文件的彻底解决方法

    最近,有PDF.NET用户问我怎么在64位系统下无法访问Access数据库的问题,我第一反应是我怎么没有遇到呢?今天一看自己的VS和Office都是32位版本的,所以在VS里面调试访问Access是没 ...

  6. window2008 64位系统没有office组件问题分析及解决

    服务器是windows server2008 64位系统, 我的系统需要用到Microsoft.Office.Interop.Excel组件 在上传Excel单据遇到错误:检索 COM 类工厂中 CL ...

  7. Windows7 64位中出现的KERNELBASE.dll错误的解决方法

    最近在服程序时遇到个问题,电脑是win764位,编译完的exe测试,偶尔总报错,报错是偶尔的,有时候报错很频繁,但是有一次测试,测试了半天都没有报错,我以为好,发布输出没一会儿又报错了,真是崩溃了,所 ...

  8. 一个伟大的发现,装X一下。笔记本win7系统64位机器执行unity 时,屏幕模糊解决的方法

    笔者笔记本win7系统64位机器执行unity 时.往往切换时unity界面屏幕模糊,后来发现此时须要下载DirectXRuntimes201006x64,安装就可以.

  9. 关于Win7 64位下:Navicat无法连接64位Oracle 11gR2:Cannot load OCI DLL解决方法

    错误描述 在Win7下安装了Oracle 11g R2,在用Navicat去连接Oracle时,提示以下错误: Cannot load OCI DLL, 126: Instant Client pac ...

随机推荐

  1. ASP.NET站点安全

    <configuration> <appSettings/> <connectionStrings> <add name="MyBookShop&q ...

  2. java的数据类型,几个java小程序

    1:求圆的面积 还好看了c++,不然直接看这课件还真是看不懂……加油吧 要从键盘读入数据可以用Scanner类的nextlnt()或者nextDouble()方法,首先创建Scanner类的一个实例, ...

  3. 仿爱乐透android客户端界面实现(附工程源码)

    最近研究了爱乐透android客户端的界面,感觉它的界面布局在一般开发中具有代表性.难点在于复杂的布局实现. 界面实现主要采用了以下方式: 注意:版本支持:android2.2以上,低版本要改动源码哦 ...

  4. Windows Phone 8初学者开发—第18部分:在页面间导航

    原文 Windows Phone 8初学者开发—第18部分:在页面间导航 原文地址:  http://channel9.msdn.com/Series/Windows-Phone-8-Developm ...

  5. RadioButtonList控件

    在这里只写,绑定数据库数据的RadioButtonList控件: 一: 首先,先在数据库中建立一张表: 1 CREATE TABLE KK 2 ( 3 id INT, 4 [name] VARCHAR ...

  6. Web端的Tab控件在切换Tab时Load数据出错的处理

    我们在应用Web端的Tab控件时,不管是Jquery easyui的还是Ext的Tab控件都会遇到一个问题,在Tab1正在加载数据的时候我们切换到Tab2,再切换回来,Load数据的控件就会出错,出错 ...

  7. CF#213DIV2:B The Fibonacci Segment

    You have array a1, a2, ..., an. Segment [l, r] (1 ≤ l ≤ r ≤ n) is good if ai = ai - 1 + ai - 2, for ...

  8. javascript重点笔记

    操作符之间的优先级(高到低):算术操作符 >比较操作符 >逻辑操作符 >"="赋值符号 算术运算符

  9. Qt国际化相关类(以前没见过codec->toUnicode,QTextCodec,QLocale.toString和QLocale::setDefault,QInputMethod::locale())

    QTextCodec QTextCodec为文本编码之间提供转换. Qt用Unicode 来存储,绘制和操作字符串.在很多情况下你可能希望操作不同编码的数据.例如,大部分日本文档是以Shift-JIS ...

  10. JS 2016-09-30T22:04:27.5220743+08:00 转换为日期

    1.转换代码 new Date(item.CreatedDate).Format("yyyy-MM-dd hh:mm") 2.需要拓展的方法 // 对Date的扩展,将 Date ...