欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C#利用反射實現(xiàn)多數(shù)據(jù)庫訪問

 更新時間:2022年03月07日 11:12:34   作者:.NET開發(fā)菜鳥  
本文詳細(xì)講解了C#利用反射實現(xiàn)多數(shù)據(jù)庫訪問的方法,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下

上一篇文章中講解了什么是反射,以及利用反射可以獲取程序集里面的哪些內(nèi)容。在平時的項目中,可能會遇到項目需要使用多種數(shù)據(jù)庫,這篇文章中將會講解如何利用反射實現(xiàn)訪問多種數(shù)據(jù)庫。

項目整體結(jié)構(gòu)如下圖所示:

1、Database.Instance是一個類庫文件,IDBHelper是一個接口,封裝的訪問數(shù)據(jù)庫數(shù)據(jù)的CURD方法,OracleDBHelper和SQLServerDBHelper類實現(xiàn)IDBHelper接口,分別用來訪問Oracle數(shù)據(jù)庫和SQL Server數(shù)據(jù)庫,接口和類的定義如下:

IDBHelper接口定義

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace Database.Instance.Interface
{
    public interface IDBHelper
    {
        /// <summary>
        /// 創(chuàng)建數(shù)據(jù)
        /// </summary>
        void Create();

        /// <summary>
        /// 更新數(shù)據(jù)
        /// </summary>
        void Update();

        /// <summary>
        /// 讀取數(shù)據(jù)
        /// </summary>
        void Retrieve();

        /// <summary>
        /// 刪除數(shù)據(jù)
        /// </summary>
        void Delete();
    }
}

OracleDBHelper類定義如下

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Database.Instance.Interface;

namespace Database.Instance.Oracle
{
   public class OracleDBHelper :IDBHelper
    {
        public void Create()
        {
            Console.WriteLine("這是Oracle數(shù)據(jù)庫執(zhí)行創(chuàng)建操作");
        }

        public void Update()
        {
            Console.WriteLine("這是Oracle數(shù)據(jù)庫執(zhí)行更新操作");
        }

        public void Retrieve()
        {
            Console.WriteLine("這是Oracle數(shù)據(jù)庫執(zhí)行讀取操作");
        }

        public void Delete()
        {
            Console.WriteLine("這是Oracle數(shù)據(jù)庫執(zhí)行刪除操作");
        }
    }
}

SQLServerDBHelper類定義如下

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Database.Instance.Interface;

namespace Database.Instance.SQL_Server
{
    public class SQLServerDBHelper:IDBHelper
    {
        public void Create()
        {
            Console.WriteLine("這是SQL Server數(shù)據(jù)庫執(zhí)行創(chuàng)建操作");
        }

        public void Update()
        {
            Console.WriteLine("這是SQL Server數(shù)據(jù)庫執(zhí)行更新操作");
        }

        public void Retrieve()
        {
            Console.WriteLine("這是SQL Server數(shù)據(jù)庫執(zhí)行讀取操作");
        }

        public void Delete()
        {
            Console.WriteLine("這是SQL Server數(shù)據(jù)庫執(zhí)行刪除操作");
        }
    }
}

2、MyReflection是一個控制臺程序,用來測試

一、使用原始方法實現(xiàn)

使用原始的方法實現(xiàn)代碼如下:

using Database.Instance.Interface;
using Database.Instance.Oracle;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Reflection;
using System.Configuration;

namespace MyReflection
{
    class Program
    {
        static void Main(string[] args)
        {
            // 實例化(調(diào)用Oracle數(shù)據(jù)庫)
            IDBHelper dbHelper = new OracleDBHelper();
            // 調(diào)用方法
            dbHelper.Create();
            dbHelper.Update();
            dbHelper.Retrieve();
            dbHelper.Delete();

            Console.ReadKey();
        }
    }
}

程序運行結(jié)果:

存在的問題:如果換一種數(shù)據(jù)庫,那么就需要修改實例化的代碼,例如更換SQL Server數(shù)據(jù)庫,那么代碼修改如下:

IDBHelper dbHelper = new SQLServerDBHelper();

這樣很不方便,每次更換數(shù)據(jù)庫的時候,都需要修改實例化的代碼,有沒有什么方便的方法可以做到不需要修改代碼就可以實現(xiàn)更換數(shù)據(jù)庫呢?辦法就是使用反射加配置文件實現(xiàn)。

二、使用反射加配置文件實現(xiàn)

配置文件結(jié)構(gòu)如下:

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <appSettings>
    <!--key表示定義的接口 value格式 要加載的程序集名稱,要實例化的類 value值中間以','分割-->
    <add key="Database.Instance.Interface.IDBHelper" value="Database.Instance,Database.Instance.Oracle.OracleDBHelper"/>
  </appSettings>
    <startup>
        <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5.1" />
    </startup>
</configuration>

Program類定義如下:

using Database.Instance.Interface;
using Database.Instance.Oracle;
using Database.Instance.SQL_Server;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Reflection;
using System.Configuration;

namespace MyReflection
{
    class Program
    {
        static void Main(string[] args)
        {
            // 根據(jù)key值讀取對應(yīng)的value值
            string[] config = ConfigurationManager.AppSettings["Database.Instance.Interface.IDBHelper"].Split(',');
            // 加載程序集 config[0]=Database.Instance
            Assembly assembly = Assembly.Load(config[0]);

            // 根據(jù)類的完全限定名找出類型 config[1]= Database.Instance.Oracle.OracleDBHelper
            Type type = assembly.GetType(config[1]);
            // 根據(jù)類型創(chuàng)建對象
            object obj = Activator.CreateInstance(type);
            //實例化
            IDBHelper dbHelper = obj as IDBHelper;
            dbHelper.Create();
            dbHelper.Update();
            dbHelper.Retrieve();
            dbHelper.Delete();
            Console.ReadKey();
        }
    }
}

 運行結(jié)果如下:

如果更新數(shù)據(jù)庫,只需要更新配置文件中value的值即可,例如要更換SQL Server數(shù)據(jù)庫,配置文件修改如下:

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <appSettings>
    <!--key表示定義的接口 value格式 要加載的程序集名稱,要實例化的類 value值中間以','分割-->
    <add key="Database.Instance.Interface.IDBHelper" value="Database.Instance,Database.Instance.SQL_Server.SQLServerDBHelper"/>
  </appSettings>
    <startup>
        <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5.1" />
    </startup>
</configuration>

 Program類不需要修改,運行結(jié)果如下:

到此這篇關(guān)于C#利用反射實現(xiàn)多數(shù)據(jù)庫訪問的文章就介紹到這了。希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • C# cefSharep控件的使用詳情

    C# cefSharep控件的使用詳情

    本文主要介紹了C# cefSharep控件的使用,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-01-01
  • C#將時間轉(zhuǎn)成文件名使用方法

    C#將時間轉(zhuǎn)成文件名使用方法

    C#將時間轉(zhuǎn)成文件名用到的是DateTime類的ToFileTime方法,下面看使用方法吧
    2014-01-01
  • C# 控制臺實現(xiàn)一次性輸入多行的操作

    C# 控制臺實現(xiàn)一次性輸入多行的操作

    這篇文章主要介紹了C# 控制臺實現(xiàn)一次性輸入多行的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-01-01
  • C#實現(xiàn)文件上傳以及多文件上傳功能

    C#實現(xiàn)文件上傳以及多文件上傳功能

    這篇文章主要為大家詳細(xì)介紹了C#實現(xiàn)文件上傳以及多文件上傳功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-05-05
  • C#線程倒計時器源碼分享

    C#線程倒計時器源碼分享

    這篇文章主要為大家分享了C#線程倒計時器源碼,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-01-01
  • C#權(quán)限管理和設(shè)計淺談

    C#權(quán)限管理和設(shè)計淺談

    權(quán)限管理是很多軟件中相當(dāng)重要的一個模塊——它的設(shè)計的好壞直接影響到軟件的安全性、權(quán)限管理的可擴(kuò)展性和易操作性 以及代碼中權(quán)限判斷的復(fù)雜程度和效率等方面
    2012-02-02
  • C#判斷字符串是否存在字母及字符串中字符的替換實例

    C#判斷字符串是否存在字母及字符串中字符的替換實例

    這篇文章主要介紹了C#判斷字符串是否存在字母及字符串中字符的替換,實例形式講述了C#針對字符串的正則操作,需要的朋友可以參考下
    2014-10-10
  • Unity Shader實現(xiàn)2D水流效果

    Unity Shader實現(xiàn)2D水流效果

    這篇文章主要為大家詳細(xì)介紹了Unity Shader實現(xiàn)2D水流效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-05-05
  • 創(chuàng)建execl導(dǎo)入工具類的步驟

    創(chuàng)建execl導(dǎo)入工具類的步驟

    這篇文章主要介紹了創(chuàng)建execl導(dǎo)入工具類的步驟,需要的朋友可以參考下
    2014-04-04
  • WPF利用TabControl控件實現(xiàn)拖拽排序功能

    WPF利用TabControl控件實現(xiàn)拖拽排序功能

    在UI交互中,拖拽操作是一種非常簡單友好的交互,這篇文章主要為大家介紹了WPF如何利用TabControl控件實現(xiàn)拖拽排序功能,需要的小伙伴可以參考一下
    2023-10-10

最新評論