C#连接Oracle数据库的方法

ops/2024/10/20 13:28:25/

C#连接Oracle数据库的方法(Oracle.DataAccess.Client也叫ODP.net)-CSDN博客

.NET连接Oracle数据库踩过的坑

1 常用数据库访问类

一般来说,C#连接Oracle数据库,我们通常会通过封装好的dll调用,目前常用的有三个:

(1)System.Data.OracleClient.dll(微软)
(2)Oracle.DataAccess.Client.dll(Oracle,也称ODP.NET)
(3)Oracle.ManagedDataAccess.dll(Oracle)

1.1 System.Data.OracleClient.dll

首先需安装Oracle客户端,然后可直接直接引用微软的System.Data.OracleClient,但VS会提示“System.Data.OracleClient.OracleConnection”已过时。经测试虽然提示过时但仍可正常使用,微软已经很久没有更新过这个访问类了,安全性方面无保障。

1.2 Oracle.DataAccess.Client.dll

Oracle提供的数据库访问类库,简称ODP.NET,其功能和效率上都有所保证,访问效率和速度都要比微软的System.Data.OracleClient优秀。

优点:
(1)无需安装Oracle客户端,程序也能访问服务器上的Oracle
(2)不需要配置tnsnames.ora文件

缺点:
(1)要区分用区分x86/x64版本

1.3 Oracle.ManagedDataAccess.dll

推荐这一种,Oracle官方出品,日常更新维护,无需安装Oracle客户端,不用区分操作系统位数。

2 踩过的坑

2.1 从System.Data.OracleClient到Oracle.ManagedDataAccess

一般来讲,我们会把数据库的连接信息写在config文件中,通过System.Configuration.dll读取,然后执行操作。

<!--tnsnames.ora中的服务名-->
xxx =(DESCRIPTION =(ADDRESS_LIST =(ADDRESS = (PROTOCOL = TCP)(HOST = x.xx.xx.xxx)(PORT = 1521)))(CONNECT_DATA =(SERVICE_NAME = orcl)))

<!--System.Data.OracleClient的数据库链接-->
<connectionStrings><add name="OracleConn" connectionString="Data Source=xxx(tnsnames.ora中配置的服务名);User ID=xxx;Password=xxx"/>
</connectionStrings>

/// <summary>
/// 获取Oracle连接字符串
/// </summary>
public class PubConstant
{public static string GetOracleConString(string conval){string connectionString  = ConfigurationManager.ConnectionStrings[conval].ToString();return connectionString;}
}

//从config文件里面获取数据库连接信息
private static readonly string connectionString = PubConstant.GetOracleConString("OracleConn");

/// <summary>
/// 执行参数化查询语句,返回DataSet
/// </summary>
public DataSet QueryByCSH(string SQLString, string cphm, string dlyszh)
{using (OracleConnection connection = new OracleConnection(connectionString)){DataSet ds = new DataSet();try{connection.Open();OracleDataAdapter command = new OracleDataAdapter(SQLString, connection);command.SelectCommand.Parameters.Add(":cphm", cphm);command.SelectCommand.Parameters.Add(":dlyszh", dlyszh);command.Fill(ds, "ds");}catch (OracleException ex){throw new Exception(ex.Message);}finally{connection.Close();}return ds;}
}

经过上面的一些列操作之后发现,每次在connection.Open()出都会报“无法识别连接字符串”的异常,已安装Oracle客户端,数据库服务器IP、端口、用户名、密码都正确,百度了好久没有结果。

2.2 从连接服务名到连接字符串

终于,无意间看见一篇名为“C#使用Oracle.ManagedDataAccess.dll”的文章,于是将连接服务名改为了连接字符串,结果成功打开数据库连接。

<!--Oracle.ManagedDataAccess的数据库链接-->
<connectionStrings><add name="OracleConn" connectionString="Data Source=(DESCRIPTION=(ADDRESS_LIST=(ADDRESS=(PROTOCOL=TCP)(HOST=x.xx.xx.xxx)(PORT=1521)))(CONNECT_DATA=(SERVICE_NAME=orcl)));User ID=xxx;Password=xxx"/>
</connectionStrings>

至此,记录下了我使用Oracle.ManagedDataAccess.dll遇到的问题,希望能给小伙伴们提供一点帮助!
参考链接:点击前往



作者:我叫397
链接:https://www.jianshu.com/p/efaba51d1cb6
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。


http://www.ppmy.cn/ops/126989.html

相关文章

navicat 3730错误

Navicat 3730 错误通常是由于在执行 SQL 语句时出现了语法错误或者其他问题导致的。具体来说&#xff0c;这个错误通常出现在 Navicat 尝试解析 SQL 语句时发现无法识别的语法或结构错误。 解决步骤 检查 SQL 语句的语法&#xff1a; 确保 SQL 语句语法正确无误。逐条执行 SQL…

子数组的最大异或和

LintCode 炼码 - 更高效的学习体验&#xff01; 子数组的最大异或和_牛客题霸_牛客网 算法&#xff1a;最大子数组异或和_异或值最大的子数组-CSDN博客 #include <iostream> #include <limits> #include <new> #include <vector> using namespace st…

Linux学习笔记9 文件系统的基础

一、查看文件组织结构 Linux中一切都是文件。 Linux和Win的文件系统不是一个结构&#xff0c;Linux存在的根目录是所有目录的起点。 所有的存储空间和设备共享一个根目录&#xff0c;不同的磁盘块和分区挂载在其下&#xff0c;成为某个子目录的子目录&#xff0c;甚至设备也挂…

【Linux】< 条件变量等待>解决< 线程饥饿问题 >——【多线程同步问题】

前言 大家好吖&#xff0c;欢迎来到 YY 滴Linux系列 &#xff0c;热烈欢迎&#xff01; 本章主要内容面向接触过C的老铁 主要内容含&#xff1a; 欢迎订阅 YY滴C专栏&#xff01;更多干货持续更新&#xff01;以下是传送门&#xff01; YY的《C》专栏YY的《C11》专栏YY的《Lin…

没有HTTPS 证书时,像这样实现多路复用

在没有 HTTPS 证书的情况下,HTTP/2 通常不能直接通过 HTTP 协议使用。虽然 HTTP/2 协议的规范是可以支持纯 HTTP 连接(即通过 http:// 协议),但大多数主流浏览器(如 Chrome、Firefox)都 强制要求 HTTP/2 必须在 HTTPS 上运行。这是出于安全和隐私的考虑。 因此,如果你没…

DNS代理是什么?浅析DNS代理的工作原理及应用

DNS代理作为计算机网络中重要的一环&#xff0c;扮演着连接用户和互联网服务的关键角色。来了解DNS代理的定义、功能、工作原理以及在网络中的应用场景和重要性吧。 一、理解DNS代理。 DNS代理充当在用户和真正的DNS服务器之间的中介。它接收来自用户端的DNS查询请求&#xf…

pytest中@pytest.fixture常用顺序function

ytest中pytest.fixture用法讲解 1、测试函数开始之前2、执行测试函数&#xff1a;3、测试函数结束后&#xff1a; 备注&#xff1a;内容来自chatGPT 在 pytest 中&#xff0c;pytest.fixture 是一个非常强大的功能&#xff0c;用于设置测试所需的环境和状态。它可以通过 scope…

SpringBoot框架下的汽车票在线预订系统

4系统概要设计 4.1概述 本系统采用B/S结构(Browser/Server,浏览器/服务器结构)和基于Web服务两种模式&#xff0c;是一个适用于Internet环境下的模型结构。只要用户能连上Internet,便可以在任何时间、任何地点使用。系统工作原理图如图4-1所示&#xff1a; 图4-1系统工作原理…