当前位置: 首页 > 图文教程 > 网络编程 > ASP.NET > .Net连接Oracle数据库的实现代码

ASP.NET
asp.net服务器上几种常见异常的解决方案.
Asp.net 下载功能的解决方案
asp.net 页面传值的几个方法
asp.net Cookie跨域、虚拟目录等设置方法
aspnet_isapi.dll设置图文方法.net程序实现伪静态
ASP.NET Web应用程序的安全解决方案浅析
asp.net 图片的读写入库实现代码
asp.net cookie的读写实例
浅析ASP.NET生成随机密码函数
asp.net 防止用户通过后退按钮重复提交表单
ASP.NET 调用百度搜索引擎的代码
asp.net用url重写URLReWriter实现任意二级域名 新
asp.net用url重写URLReWriter实现任意二级域名 高级篇
asp.net 下载文件时根据MIME类型自动判断保存文件的扩展名
asp.net 文件上传 实时进度
asp.net+jquery Gridview的多行拖放, 以及跨控件拖放
ASP.NET 页面之间传递值方式优缺点比较
asp.net 页面转向 Response.Redirect, Server.Transfer, Server.Execute的区别
ASP.NET 返回随机数实现代码
asp.net FreeTextBox配置详解

ASP.NET 中的 .Net连接Oracle数据库的实现代码


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-11   浏览: 69 ::
收藏到网摘: n/a

本文使用System.Data.OracleClient方式,这是MS提供的以ADO.NET方式访问Oracel的驱动;Oracle也有个Oracle Data Provider for .NET(ODP.NET)下篇再讨论。

访问Oracle时客户端(或者web服务器)得安装一个Oracle的客户端,这个有点不爽,SQL Server不用呀,MySQL顶多来个MySql.Data.dll 就搞定。寻觅了很久找到一个相对苗条的客户端,才12M多、小巧实用呀。安装后如下:

一个类似查询分析器的连接与查询工具,一个配置文件(很重要)。

启动连接工具

输入帐号信息,对应的是连接字符串的user id,password,datasource


连接成功后就可以查询了,这玩意看起来想windows程序,貌似像是一个dos命令行工具,输入完sql得选择"文件/运行" 执行SQL

配置文件(使用前应该先配置此文件),因为是精简版,没有图形化工具配置,所有就Notepad了

#DATABASENAME =
# (DESCRIPTION
=
# (ADDRESS_LIST
=
# (ADDRESS
= (PROTOCOL = TCP)(HOST = 127.0.0.1)(PORT = 1521))
# )
# (CONNECT_DATA
=
# (SERVICE_NAME
= servicename)
# )
# )

更改这个注释过的例子配置

myOracle =
(DESCRIPTION
=
(ADDRESS_LIST
=
(ADDRESS
= (PROTOCOL = TCP)(HOST = 33.33.33.33)(PORT = 1521))
)
(CONNECT_DATA
=
(SERVICE_NAME
= mysid)
)
)

其中,myOracle是随便起的名子,连接字符串的data source=这里的myOracle;HOST,PORT不用说了;SERVICE_NAME = mysid 填服务端数据库实例的SID,这里应该是确定了那个数据库了。

配置完成后就可以在程序中访问Oracle,以下举例获取一个表的数据显示在页面

using System.Data.OracleClient;

OracleConnection con = new OracleConnection("Data Source=myOracle;user id=xxx;password=xxx;");
OracleCommand cmd
= new OracleCommand("select * from table", con);
con.Open();
OracleDataReader dr
= cmd.ExecuteReader(CommandBehavior.CloseConnection);
GridView1.DataSource
= dr;
GridView1.DataBind();
dr.Close();

--显示所有表信息,类似mysql的show tables
select * from all_tables
--显示前几条,类似sqlserver的select top
select * from tb WHERE ROWNUM <=5
--from表名应该为OWNER.TABLE_NAME
select * from ms.mytable
--参数符号不同,oracle中为: sqlserver中为@ mysql中为?
select * from tab where id=:myid