备忘录:关于.net程序连接Oracle数据库
志铭-2021年12月7日 21:22:15
关于使用MSSM访问Oracle数据库
- 安装访问接口组件:OraOLEDB.Oracle
- 官网可以下载,但是需要注册
- 下载地址:https://pan.baidu.com/s/1OpYmpReEJcPg4wNESWy61Q
- 要求服务器至少安装. net2.0和. net3.5
- 我参考的教程:http://www.manongjc.com/article/11212.html
- 我本机win10,SQLSERVER2019
- 安装该教程中需要注意的是:
-
在修改了环境变量后,不需要修改注册表的操作
-
创建链接服务器时,数据源参数IP/sid ,不需要使用端口
-
参考2: https://blog.csdn.net/weixin_42996498/article/details/88717706
-
关于. net 程序中连接Oracle数据库
-
使用Oracle.ManagedDataAccess.Client.dll
- 该程序集对.net无版本要求
- nuget:Install-Package Oracle.ManagedDataAccess -Version 19.13.0
- 注意我没有使用最新21.4.0版本,该最新版本依赖另外一个类库System.Text.Json (>= 5.0.2),而且对.net版本有要求
-
注意:注意不要使用System.Data.OracleClient,vs会提示过时
-
关于Oracle数据库连接字符串格式参考:
<connectionStrings> <add name="connStringForOracle" connectionString="user id=用户ID;password=密码;data source=(DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=服务IP地址)(PORT=端口号))(CONNECT_DATA=(SERVER=服务名)(SERVICE_NAME=服务名)))" /> </connectionStrings>
-
简易的封装一个Oracle辅助类:
//添加命名空间:using Oracle.ManagedDataAccess.Client; public class OracleHelper { private static readonly string connectionString = System.Configuration.ConfigurationManager.ConnectionStrings["connStringForOracle"].ToString(); //创建连接对象 public static OracleConnection GetConn() { var conn = new OracleConnection(connectionString); conn.Open(); return conn; } //执行非查询语句返回受影响行数 public static int ExecuteNoQuery(string sql,CommandType type=CommandType.Text,params SqlParameter[] param) { using (var conn = GetConn()) { using (OracleCommand cmd=new OracleCommand (sql,conn)) { if (null!=param) { cmd.Parameters.AddRange(param); } cmd.CommandType = type; return cmd.ExecuteNonQuery(); } } } //返回查询结果的第一行第一个单元格的数据 public static object ExecuteScalar(string sql,CommandType type=CommandType.Text,params SqlParameter[] param) { using (var conn = GetConn()) { using (OracleCommand cmd=new OracleCommand(sql,conn)) { if (null!=param) { cmd.Parameters.AddRange(param); } cmd.CommandType = type; return cmd.ExecuteScalar(); } } } //返回查询结果集 public static DataSet GetDataSet(string sql, CommandType type = CommandType.Text, params SqlParameter[] param) { using (var conn = GetConn()) { using (OracleDataAdapter adapter = new OracleDataAdapter(sql, conn)) { if (null != param) { adapter.SelectCommand.Parameters.AddRange(param); } adapter.SelectCommand.CommandType = type; DataSet ds = new DataSet(); adapter.Fill(ds); return ds; } } } }
Navicat Premium 连接远程Oracle
- 使用TNS方式连接 ,其网络服务器名称,和程序中配置文件的连接字符串格式类似
- 连接名:自定义即可
- 连接类型:TNS
- 网络服务名称:
(DESCRIPTION =(ADDRESS=(PROTOCOL=TCP)(HOST =XXX.XXX.XXX.XXX)(PORT =1521))(CONNECT_DATA =(SERVICE_NAME=服务器名称)))
- 用户名
- 密码
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 【杭电多校比赛记录】2025“钉耙编程”中国大学生算法设计春季联赛(1)
2020-12-08 基于.NET的程序读取Excel文件的解决方案