C#使用Oracle.ManagedDataAccess.dll

来源:http://www.cnblogs.com/goldenbridge/archive/2017/11/09/7812081.html
-Advertisement-
Play Games

在剛接觸C#的時候由於公司使用的就是Oracle資料庫,那麼C#怎麼連接Oracle資料庫就成了首要去掌握的知識點了。在那時沒有ODP.NET,但visual studio卻對Oralce資料庫的調用進行了集成,就是下圖中的這個,儘管現在使用這個的時候visual studio提醒過時的,但在那時卻 ...


在剛接觸C#的時候由於公司使用的就是Oracle資料庫,那麼C#怎麼連接Oracle資料庫就成了首要去掌握的知識點了。在那時沒有ODP.NET,但visual studio卻對Oralce資料庫的調用進行了集成,就是下圖中的這個,儘管現在使用這個的時候visual studio提醒過時的,但在那時卻是非常好用的。

為什麼現在visual studio中這個程式集依然能使用,有ODP.NET,單單要拿出Oracle.ManagedDataAccess.dll進行本文的重點呢?

1、visual studio中提醒過時,因為微軟和甲骨文存在資料庫的競爭關係,並且從.NET的更新來看這個程式集沒有再更新過,對於資料庫一直在更新而調用的程式集一直不更新敢用下去麽?還有一個我認為非常重要的原因就是使用這個程式集,擺脫不了每一個運行程式的客戶機上都要去安裝Oracle客戶端的事實,試想一下,如果用戶數量巨大的時候,安裝客戶端的工作量就相當的大,很耗費資源;

2、甲骨文後來出了ODP.NET,各種資料以及官網上都說需要安裝ODP.NET,然後引用Oracle.ManagedDataAccess.dll,他和visual studio中的程式集最大的區別在於會隨著資料庫更新,是oracle官方出的驅動;

3、其實經過測試,ODP.NET的安裝完全是沒有必要的,直接在網上下載一個Oracle.ManagedDataAccess.dll,按如下方式引用即可,使用此種方式減少了ODP.NET的安裝,無視操作系統的位數,最重要的是減少了Oracle客戶端的安裝;

 

那在哪裡下載Oracle.ManagedDataAccess.dll呢?如果Oracle.ManagedDataAccess.dll有更新怎麼知道呢?這個時候全宇宙最強大開發工具登場了!

安裝完成就可以擼代碼了,並且如果有更新可以隨時能看到。並且在編程方面和以前使用System.Data.OracleClient程式集沒有多大的不同,基本上拿以前使用System.Data.OracleClient程式集的代碼做少許的改動即可。

1、使用了連接字元串,而不是用oracle客戶端的服務名了;

2、幾個命名空間的變化;

下麵是對資料庫常用操作的封裝

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 執行SQL語句,返回受影響行數
        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 執行SQL語句,返回DataTable;只用來執行查詢結果比較少的情況
        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
    }
}

以下代碼是調用部分

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

 

程式編寫完成,生成完成後,目錄大概如下:

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

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一個新的項目需要用到系統置頂的功能,本來是件很簡單的事情,但是越做發現並不那麼簡單,所以記錄下來: 系統環境:win7旗艦版本64位; IDE :VS2013; WPF+C#開發。 一、開始用Topmost屬性設置為true。 運行木有問題,很簡單喲。呵呵,隨後運行打開osk.exe;卵,被按下去了 ...
  • .Net 傳統非同步編程概述 .NET Framework 提供以下兩種執行 I/O 綁定和計算綁定非同步操作的標準模式: 非同步編程模型 (APM),在該模型中非同步操作由一對 Begin/End 方法(如 FileStream.BeginRead 和 Stream.EndRead)表示。 基於事件的非同步 ...
  • 現在在做的項目美工要求比較高,所以根據網上搜索的資料,自定義了一整套的彈出框,供大家參考,之網上其他大神有調用系統ICO的,容易導致異常,我在此使用本地資源ICO,效率高不異常。using System; using System.Drawing; using System.Drawing.Draw... ...
  • 項目實際開發中需要根據不同的應用場景利用Show和ShowDialog,尤其是三級彈窗,慎用ShowDialog,否則會導致關閉第三級窗體時,自動關閉第二級,解決方案就是在第一級窗體彈出時採用Show(this)的方法。 ...
  • 一、前言 .net core 2.0正式版已經發佈幾個月了,經過研究,決定把項目轉移過來,新手的話可以先看一些官方介紹 傳送門:https://docs.microsoft.com/zh-cn/dotnet/core/ 由於在領域設計模型上遇到了一些坑,故給大家分享出來自己的一些解決方案。 ok,直 ...
  • 【GetData1】 【GetData2】 【GetData3】 【GetData4】 【GetData5】 【GetData6】 【GetData7】 【GetData8】 【GetData9】 【GetData10】 【GetData11】 【GetData12】 【GetData13】 【Ge ...
  • 在C#中通過使用方法來獲取返回值時,通常只能得到一個返回值。因此,當一個方法需要返回多個值的時候,就需要用到ref和out,那麼這兩個方法區別在哪兒呢? MSDN: ref 關鍵字使參數按引用傳遞。其效果是,當控制權傳遞迴調用方法時,在方法中對參數所做的任何更改都將反映在該變數中。若要使用 ref  ...
  • ASP.NET Core 是一個跨平臺的,高性能,開源框架,用於生成基於雲且連接 Internet 的新式應用程式。我們可以使用 ASP.NET Core: 生成 Web 應用和服務、IoT 應用和移動後端。 在 Windows、macOS 和 Linux 上使用喜愛的開發工具。 部署到雲或本地 在 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...