[置顶] 64位Win2008_VS2012使用ODP.NET遭遇问题和解决办法
最近为使用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遭遇问题和解决办法的更多相关文章
- 64位Win2008_VS2012使用ODP.NET遭遇问题和解决办法
原文地址:64位Win2008_VS2012使用ODP.NET遭遇问题和解决办法 最近为使用Oracle11G数据库做个快速开发的小程序,使用64位Win2008+Vs2012环境,结果碰壁连环,幸好 ...
- 64位Windows7升级IE11后无法启动的解决办法
1.控制面板\网络和 Internet\Internet选项 2.在高级选项卡的“安全”组配置
- 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 ...
- 64位 SQL Server2008链接访问Oracle 过程汇总解决方法记录
64位 SQL Server2008链接访问Oracle 过程汇总解决方法记录 经过几天不停的网上找资料,实验,终于联通了. 环境:系统:win 2008 ,SqlServer2008 R2, 连接O ...
- 64位系统使用Access 数据库文件的彻底解决方法
最近,有PDF.NET用户问我怎么在64位系统下无法访问Access数据库的问题,我第一反应是我怎么没有遇到呢?今天一看自己的VS和Office都是32位版本的,所以在VS里面调试访问Access是没 ...
- window2008 64位系统没有office组件问题分析及解决
服务器是windows server2008 64位系统, 我的系统需要用到Microsoft.Office.Interop.Excel组件 在上传Excel单据遇到错误:检索 COM 类工厂中 CL ...
- Windows7 64位中出现的KERNELBASE.dll错误的解决方法
最近在服程序时遇到个问题,电脑是win764位,编译完的exe测试,偶尔总报错,报错是偶尔的,有时候报错很频繁,但是有一次测试,测试了半天都没有报错,我以为好,发布输出没一会儿又报错了,真是崩溃了,所 ...
- 一个伟大的发现,装X一下。笔记本win7系统64位机器执行unity 时,屏幕模糊解决的方法
笔者笔记本win7系统64位机器执行unity 时.往往切换时unity界面屏幕模糊,后来发现此时须要下载DirectXRuntimes201006x64,安装就可以.
- 关于Win7 64位下:Navicat无法连接64位Oracle 11gR2:Cannot load OCI DLL解决方法
错误描述 在Win7下安装了Oracle 11g R2,在用Navicat去连接Oracle时,提示以下错误: Cannot load OCI DLL, 126: Instant Client pac ...
随机推荐
- mysql select简单用法
1.select语句可以用回车分隔 $sql="select * from article where id=1" 和 $sql="select * from artic ...
- Intent过滤,intent-filter
Intent过滤 编写:kesenhoo - 原文:http://developer.android.com/training/basics/intents/filters.html 前两节课主要讲了 ...
- Android访问网络(可以正常使用)
以下是MainActiviy.java,有必要的注释,里面用到了handler,以及线程,workThread如何更新mainThread才能够更新的内容. package com.wyl.httpt ...
- Appium 服务命令行参数
Appium 可以直接通过命令行启动,同样支持命令行参数配置 参考: http://appium.io/slate/cn/master/ 使用方法 例如: appium --shell 服务器标志 ...
- Linux gcc/g++下GDB调试及其调试脚本的使用
GDB调试及其调试脚本的使用返回脚本百事通一.GDB调试 1.1. GDB 概述 GDB 是GNU开源组织发布的一个强大的UNIX下的程序调试工具.或许,各位比较喜欢那种图形界面方式的,像VC.BCB ...
- (转)Free函数的参数一定要是malloc返回的那个指针
Free函数的参数一定要是malloc返回的那个指针 之前认为只要free的参数在malloc分配的区域之内就可以了, 现在发现不对的.在嵌入式里分配堆都是按照块来的,只要在这个块内系统就能识别, ...
- POJ 1041 John's trip 无向图的【欧拉回路】路径输出
欧拉回路第一题TVT 本题的一个小技巧在于: [建立一个存放点与边关系的邻接矩阵] 1.先判断是否存在欧拉路径 无向图: 欧拉回路:连通 + 所有定点的度为偶数 欧拉路径:连通 + 除源点和终点外都为 ...
- commoncrawl 源码库是用于 Hadoop 的自定义 InputFormat 配送实现
commoncrawl 源码库是用于 Hadoop 的自定义 InputFormat 配送实现. Common Crawl 提供一个示例程序 BasicArcFileReaderSample.java ...
- java Native 方法
一. 什么是Native Method 简单地讲,一个Native Method就是一个java调用非java代码的接口.一个Native Method是这样一个java的方法:该方法的实现由非j ...
- ListView 使用方法(Asp.Net)
您将须要用到的独有数据绑定控件. Fritz Onion 代码下载位置: ExtremeASPNET2008_03.exe (192 KB) Browse the Code Online 文件夹 L ...