溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

C#連接Oracle數(shù)據(jù)庫(kù)使用Oracle.ManagedDataAccess.dll

發(fā)布時(shí)間:2020-09-29 03:29:16 來(lái)源:腳本之家 閱讀:727 作者:上青天攬?jiān)?/span> 欄目:編程語(yǔ)言

在剛接觸C#的時(shí)候由于公司使用的就是Oracle數(shù)據(jù)庫(kù),那么C#怎么連接Oracle數(shù)據(jù)庫(kù)就成了首要去掌握的知識(shí)點(diǎn)了。在那時(shí)沒(méi)有ODP.NET,但visual studio卻對(duì)Oralce數(shù)據(jù)庫(kù)的調(diào)用進(jìn)行了集成,就是下圖中的這個(gè),盡管現(xiàn)在使用這個(gè)的時(shí)候visual studio提醒過(guò)時(shí)的,但在那時(shí)卻是非常好用的。

C#連接Oracle數(shù)據(jù)庫(kù)使用Oracle.ManagedDataAccess.dll

為什么現(xiàn)在visual studio中這個(gè)程序集依然能使用,有ODP.NET,單單要拿出Oracle.ManagedDataAccess.dll進(jìn)行本文的重點(diǎn)呢?

1、visual studio中提醒過(guò)時(shí),因?yàn)槲④浐图坠俏拇嬖跀?shù)據(jù)庫(kù)的競(jìng)爭(zhēng)關(guān)系,并且從.NET的更新來(lái)看這個(gè)程序集沒(méi)有再更新過(guò),對(duì)于數(shù)據(jù)庫(kù)一直在更新而調(diào)用的程序集一直不更新敢用下去么?還有一個(gè)我認(rèn)為非常重要的原因就是使用這個(gè)程序集,擺脫不了每一個(gè)運(yùn)行程序的客戶機(jī)上都要去安裝Oracle客戶端的事實(shí),試想一下,如果用戶數(shù)量巨大的時(shí)候,安裝客戶端的工作量就相當(dāng)?shù)拇?,很耗費(fèi)資源;

2、甲骨文后來(lái)出了ODP.NET,各種資料以及官網(wǎng)上都說(shuō)需要安裝ODP.NET,然后引用Oracle.ManagedDataAccess.dll,他和visual studio中的程序集最大的區(qū)別在于會(huì)隨著數(shù)據(jù)庫(kù)更新,是oracle官方出的驅(qū)動(dòng);

3、其實(shí)經(jīng)過(guò)測(cè)試,ODP.NET的安裝完全是沒(méi)有必要的,直接在網(wǎng)上下載一個(gè)Oracle.ManagedDataAccess.dll,按如下方式引用即可,使用此種方式減少了ODP.NET的安裝,無(wú)視操作系統(tǒng)的位數(shù),最重要的是減少了Oracle客戶端的安裝;

C#連接Oracle數(shù)據(jù)庫(kù)使用Oracle.ManagedDataAccess.dll

C#連接Oracle數(shù)據(jù)庫(kù)使用Oracle.ManagedDataAccess.dll

C#連接Oracle數(shù)據(jù)庫(kù)使用Oracle.ManagedDataAccess.dll

那在哪里下載Oracle.ManagedDataAccess.dll呢?如果Oracle.ManagedDataAccess.dll有更新怎么知道呢?這個(gè)時(shí)候全宇宙最強(qiáng)大開(kāi)發(fā)工具登場(chǎng)了!

C#連接Oracle數(shù)據(jù)庫(kù)使用Oracle.ManagedDataAccess.dll

C#連接Oracle數(shù)據(jù)庫(kù)使用Oracle.ManagedDataAccess.dll

C#連接Oracle數(shù)據(jù)庫(kù)使用Oracle.ManagedDataAccess.dll

安裝完成就可以擼代碼了,并且如果有更新可以隨時(shí)能看到。并且在編程方面和以前使用System.Data.OracleClient程序集沒(méi)有多大的不同,基本上拿以前使用System.Data.OracleClient程序集的代碼做少許的改動(dòng)即可。

1、使用了連接字符串,而不是用oracle客戶端的服務(wù)名了;

2、幾個(gè)命名空間的變化;

下面是對(duì)數(shù)據(jù)庫(kù)常用操作的封裝

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Configuration;
using Oracle.ManagedDataAccess.Client;
using System.Data;
using System.IO;
using System.Collections;
using System.Diagnostics;
using Oracle.ManagedDataAccess.Types;

namespace OracleDemo
{
  public class OracleHelper
  {
    private static string connStr = "User Id=admin;Password=123;Data Source=(DESCRIPTION=(ADDRESS_LIST=(ADDRESS=(PROTOCOL=TCP)(HOST=192.168.0.1)(PORT=1521)))(CONNECT_DATA=(SERVICE_NAME=test)))";

    #region 執(zhí)行SQL語(yǔ)句,返回受影響行數(shù)
    public static int ExecuteNonQuery(string sql, params OracleParameter[] parameters)
    {
      using (OracleConnection conn = new OracleConnection(connStr))
      {
        conn.Open();
        using (OracleCommand cmd = conn.CreateCommand())
        {
          cmd.CommandText = sql;
          cmd.Parameters.AddRange(parameters);
          return cmd.ExecuteNonQuery();
        }
      }
    }
    #endregion
    #region 執(zhí)行SQL語(yǔ)句,返回DataTable;只用來(lái)執(zhí)行查詢(xún)結(jié)果比較少的情況
    public static DataTable ExecuteDataTable(string sql, params OracleParameter[] parameters)
    {
      using (OracleConnection conn = new OracleConnection(connStr))
      {
        conn.Open();
        using (OracleCommand cmd = conn.CreateCommand())
        {
          cmd.CommandText = sql;
          cmd.Parameters.AddRange(parameters);
          OracleDataAdapter adapter = new OracleDataAdapter(cmd);
          DataTable datatable = new DataTable();
          adapter.Fill(datatable);
          return datatable;
        }
      }
    }
    #endregion
  }
}

以下代碼是調(diào)用部分

 string sqlString = "Select a.col1,a.col2 From test a Where a.id=:id";
 DataTable dt = OracleHelper.ExecuteDataTable(sqlString,new OracleParameter(":id",1));

程序編寫(xiě)完成,生成完成后,目錄大概如下:

C#連接Oracle數(shù)據(jù)庫(kù)使用Oracle.ManagedDataAccess.dll

這時(shí)候拷貝Debug文件夾到目標(biāo)客戶電腦上即可直接運(yùn)行了(前提是目標(biāo)客戶電腦上有.NET Framework),完全擺脫安裝Oracle客戶端。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持億速云。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI