win8下在microsoft visual studio 2012利用ODP.NET连接ORACLE 12c
老板要求我搭个ASP.NET框架,并且连接上ORACLE数据库,听起来好像挺简单的,但就是连第一步连接ORACLE我都搞了两天╮(╯▽╰)╭
首先,项目书上要求用ORACLE 10G,可我自己的本本装的WIN8,尝试地装了下ORACLE 10G失败,而且界面丑的一笔,于是放弃治疗了。
上ORACLE官网看了下,现在都出到ORACLE 12c了,果断来了一发,照着网上的安装教程磕磕巴巴终于装上了。教程如下地址:
这里,我设置的全局数据库名是orcl,密码为Oracle12c(好像ORACLE的密码必须要有大小写配合)。
安装完毕之后,用自带的SQL Plus登录进去,用户名为SYSTEM,密码为Oracle12c,ORACLE比较操蛋啊,之前在MYSQL的语句都不好用了。
总结几条:
// 查询所有表(分号一定要有)
select table_name from all_tables; // 查询用户下的所有表
select table_name from user_tables; // 显示表内数据
select * from myoracle;
有点兴奋,可是好戏在后头 .. 我一直在寻找PLSQL Developer,找了半天咋没有呢 .. 在东软电脑上都有啊,百度了一下原来他妈的这玩意还要自己装。
ORACLE官网上木有这玩意,我在其他地方下了一个,装上,发现不好使,他妈的,郁闷了,这时候不懂怎么办了。
各种百度啊,并且在visual studio12里写代码测试能不能连上,虽然百度上方法很多,可是没一个能好用的,真是纠结出翔。
偶然我怀疑是不是有组件没装,又是各种百度,居然真是!我还没装ORACLE客户端!真笨啊!搞了半天才发现这么傻的问题!
我的ORACLE是12c release 12.1.0.1.0的,所以下了ODTwithODAC121010包,里面包括:
虽然找到了原因,但这时候我又担心不会把这些组件都装上以后又有什么新问题吧,果然不出我所料!妈瞎啊妈瞎真是fuck啊!
各种试,试了PLSQL Developer不行,试了visual studio12里的ODBC,OLE DB,ODP.NET托管驱动程序还是不行!
ORA-12154: TNS: 无法解析指定的连接标识符
然后我又是各种百度啊!各种试各种不成功!到最后,终于有一个好用的了!那就是:
在D:\MySoftware\app\gomez\product\12.1.0\dbhome_1\NETWORK\ADMIN\ listener.ora里加上一些配置。
本来是这样的:
# listener.ora Network Configuration File: D:\MySoftware\app\gomez\product\12.1.0\dbhome_1\network\admin\listener.ora
# Generated by Oracle configuration tools. SID_LIST_LISTENER =
(SID_LIST =
(SID_DESC =
(SID_NAME = CLRExtProc)
(ORACLE_HOME = D:\MySoftware\app\gomez\product\12.1.0\dbhome_1)
(PROGRAM = extproc)
(ENVS = "EXTPROC_DLLS=ONLY:D:\MySoftware\app\gomez\product\12.1.0\dbhome_1\bin\oraclr12.dll")
)
) LISTENER =
(DESCRIPTION_LIST =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1521))
(ADDRESS = (PROTOCOL = TCP)(HOST = WMW-PC)(PORT = 1521))
)
)
修改后是这样的:
# listener.ora Network Configuration File: D:\MySoftware\app\gomez\product\12.1.0\dbhome_1\network\admin\listener.ora
# Generated by Oracle configuration tools. SID_LIST_LISTENER =
(SID_LIST =
(SID_DESC =
(GLOBAL_HOME = orcl)
(ORACLE_HOME = D:\MySoftware\app\gomez\product\12.1.0\dbhome_1)
(SID_NAME = ORCL)
)
(SID_DESC =
(SID_NAME = CLRExtProc)
(ORACLE_HOME = D:\MySoftware\app\gomez\product\12.1.0\dbhome_1)
(PROGRAM = extproc)
(ENVS = "EXTPROC_DLLS=ONLY:D:\MySoftware\app\gomez\product\12.1.0\dbhome_1\bin\oraclr12.dll")
)
) LISTENER =
(DESCRIPTION_LIST =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1521))
(ADDRESS = (PROTOCOL = TCP)(HOST = WMW-PC)(PORT = 1521))
)
)
-------------------------------------------------
还有就是本来在装完客户端之后,D:\MySoftware\app\gomez\product\12.1.0\client_1\Network\Admin这个路径下只有Sample文件夹,
参照D:\MySoftware\app\gomez\product\12.1.0\dbhome_1\NETWORK\ADMIN,这里不仅有Sample文件夹,还有listener.ora,tnsnames.ora,sqlnet.ora还有sqlnet13122912下午2119.bak(本来想用xxx等 .. 感觉程序员还是不要那么马虎),
所以我就把D:\MySoftware\app\gomez\product\12.1.0\client_1\Network\Admin\Sample里的sqlnet.ora和tnsnames.ora都拷出来,不知道有没有用(*^__^*)
-------------------------------------------------
然后重启服务OracleOraDB12Home1TNSListener,再试一试PLSQL,我擦进去了!
吊炸天了,赶紧试一试ODP.NET,也可以了!
然后接下来就是怎么用语句来实现对ORACLE数据库的查看、存储等等操作了。
先在ODTwithODAC121010里找到Oracle.DataAccess.Client.dll,具体位置是ODTwithODAC121010\stage\Components\oracle.ntoledb.odp_net_2\12.1.0.1.0\1\DataFiles里的filegroup10.jar,解压可得到Oracle.DataAccess.Client.dll,再将其添加到本项目的引用中来,然后在代码里添加using。
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Data.Odbc;
using Oracle.DataAccess.Client; namespace ConsoleApplication1
{
class Program
{
static void Main(string[] args)
{
// 连接数据库
string conn = "DATA SOURCE=ORCL;PERSIST SECURITY INFO=True;USER ID=SYSTEM;Password=Oracle12c";
OracleConnection odpCon = new OracleConnection(conn);
odpCon.Open(); // 插入数据
string sqlinsert = "insert into myoracle values(6,'yh')";
using (OracleCommand comm_insert = new OracleCommand(sqlinsert, odpCon))
{
using (OracleDataReader rdr_insert = comm_insert.ExecuteReader())
{ }
} // 查询数据
string sqlselect = "select * from myoracle";
using (OracleCommand comm = new OracleCommand(sqlselect, odpCon))
{
using (OracleDataReader rdr = comm.ExecuteReader())
{
while (rdr.Read())
{
Console.Write("ID ");
Console.Write(rdr.GetString());
Console.Write(", NAME: ");
Console.WriteLine(rdr.GetString());
}
}
}
}
}
}
代码很简单,不想解释了,跑起来是酱紫的。
好,到此为止,我已经可以在win8操作系统下用ODP.NET在visual studio 2012里利用代码连接到ORACLE 12C做一些必要操作了。
-------------------------------------------------
还有问题么?有的!ODBC,OLE DB等等还是不行!
ODBC数据源配置还是不好搞,搞来搞去还是错的!
非常不理想啊!说是体系结构不匹配,我的操作系统是64位的,数据库也是64位的,客户端没说是多少位的,ODBC数据源32和64的都设置过都不行。
还有OLE DB也还是不行,据visual studio 2012提示说可供连接到的最高版本为10g,那还玩个毛线!
还有一种!好像visual studio 2012的“引用”里面都没有这个库了 %>_<%
╮(╯▽╰)╭哎,ODBC & OLE DB & Oracle Client 这3种方法我暂时就放弃治疗了 .. 等过几天可能要在其他电脑搭XP+Oracle 10g什么的时候 ..
那个时候应该绕不过去这个了,那时候有进展再来详述,今天总算不是没有收获了!接来下加油继续搞下去!
win8下在microsoft visual studio 2012利用ODP.NET连接ORACLE 12c的更多相关文章
- 【解决】Microsoft Visual Studio 2012 打开2008下编译的silverlight3项目
最近因为项目需要,老师要我搞一发流程设计器,毫无头绪呀妈蛋 .. 我考虑是用silverlight呢还是jquery .. 上网找了找 .. 有一个用silverlight3写的 貌似IDE用的是V ...
- Microsoft Visual Studio 2012 文档 下载地址 vs2012 中文帮助文档
https://www.microsoft.com/zh-cn/download/confirmation.aspx?id=34794 下载地址: http://download.microsoft. ...
- Microsoft Visual Studio 2012正式版官方下载
Microsoft Visual Studio 2012正式版官方下载 首先声明,看到园子里还没有类似的新闻,所以斗胆发首页,如有不妥之处,请移除并谅解. 虽然之前已经又用到泄露的MSDN正式版,但今 ...
- Microsoft Visual Studio 2012旗舰版(VS2012中文版下载)官方中文版
Microsoft Visual Studio 2012 Ultimate旗舰版(VS2012中文版下载)是一个最先进的开发解决方案,它使各种规模的团队能够设计和创建出使用户欣喜的引人注目的应用程序. ...
- Microsoft Visual Studio 2012 添加实体数据模型
Microsoft Visual Studio 2012 添加实体数据模型 1.创建一个web项目 2.添加ADO实体数据模型,如下图: 3.选择 从数据库生成,然后下一步 4.新建连接,如下图: ...
- Microsoft Visual Studio 2012 Update 4 RC 3 离线安装程序
Microsoft Visual Studio 2012 Update 4 RC 3 离线安装程序 ☆ 微软官网地址:☆ http://www.microsoft.com/en-us/download ...
- Windows7下Blend for Visual Studio 2012使用问题
目前开发的系统里很多控件样式和动画比较复杂,应该是之前同事用Blend做的,这种神器不用太浪费了,自己也准备试试. 系统环境Windows7+Visual Studio 2012 1.Windows7 ...
- Microsoft Visual Studio 2012注册密钥
Microsoft Visual Studio Ultimate 2012 旗舰版 有效注册密钥:YKCW6-BPFPF-BT8C9-7DCTH-QXGWCMicrosoft Visual Studi ...
- 解决方案-Microsoft Visual Studio 2012 已停止工作
问题: 根本解决方案: 用管理员模式运行. 找到软件的安装目录 \Microsoft Visual Studio 11.0\Common7\IDE\devenv.exe 然后如何保存管理员权限运行呢? ...
随机推荐
- 九度OJ 1107 搬水果 -- 哈夫曼树 2011年吉林大学计算机研究生机试真题
题目地址:http://ac.jobdu.com/problem.php?pid=1107 题目描述: 在一个果园里,小明已经将所有的水果打了下来,并按水果的不同种类分成了若干堆,小明决定把所有的水果 ...
- 模板:优先队列(priority_queue)
#include <iostream> #include <cstdio> #include <queue> #include <vector> usi ...
- Cookies和Sseeion的选择
Cookies和Session都是用来记录个人信息 来保持页面状态 现在介绍些Cookies 的优点 1 把存储数据的压力分担到了客户端 ,这样服务器就少点压力 2 可以用来记录用户状态(如放入用户 ...
- 深度优化LNMP之Nginx [2]
深度优化LNMP之Nginx [2] 配置Nginx gzip 压缩实现性能优化 1.Nginx gzip压缩功能介绍 Nginx gzuo压缩模块提供了压缩文件内容的功能,用户请求 ...
- thinkphp 杂乱笔记(1)
部署模式可用两个单入口表示前后台thinkphpUploadspublic Home(前台)Admin(后台)index.php(前台入口文件)admin.php(后台入口文件)上面两个项目目录 也可 ...
- 在Apache下开启SSI配置支持include shtml html和快速配置服务器
作为前端开发,使用Apache快速搭建服务器极为方便. 1.找到apach安装目录,找到conf目录下 的httpd.conf 使用SSI(Server Side Include)的html文件扩展名 ...
- JS获取IP、MAC和主机名的五种方法
javascript获取客户端IP的小程序,下面的代码是我在所有windowsNT5.0及以上的系统上都测试通过的,喜欢的朋友可以收藏下.今天在搞JS(javascript)获取客户端IP的小程序,上 ...
- python【第二十一篇】Django模板继承、分页、cookie验证
1.模板继承 母版master.html {% block title %}{% endblock %}2 {% block table-cont %}{% endblock %} 子板 {% ext ...
- ConfigParser---python
# !/usr/bin/python # Filename:tcfg.py import ConfigParser config = ConfigParser.ConfigParser() confi ...
- 跨线程操作UI控件
写程序的时候经常会遇到跨线程访问控件的问题,看到不少人去设置Control.CheckForIllegalCrossThreadCalls = false;这句话是告诉编译器不要对跨线程访问作检查,可 ...