程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> C# >> 關於C# >> c#中的數據庫訪問工廠

c#中的數據庫訪問工廠

編輯:關於C#

上午看到一個兄弟的文章,很辛苦的想實現不改代碼只改配置來訪問不同類型的數據庫,自己去實現工廠模式。精神可嘉,但是殊不知c#已經自己為不同類型數據庫的訪問做了一個工廠。在這裡我就把使用工廠的例子貼出來供不知道的兄弟參考一下,高手們可以忽略了。

首先是配置文件:其中的providerName就是指定的不同數據庫類型

<connectionStrings>
    <add name="..." connectionString=" ..." providerName="System.Data.OleDb" />

    <add name="..." connectionString=" ..." providerName="System.Data.SqlClient" />
  </connectionStrings>

下面看一下使用工廠的這個類:

class DataBaseFac
  {
    private DbConnection cnn;//抽象類型
    private DbCommand cmd;//抽象類型
    private DbProviderFactory provider;
    public DataBaseFac()
    {

      //從配置文件中取出標示數據庫類型的字符串
      string providerName = ConfigurationManager.ConnectionStrings[1].ProviderName;

      //根據上一部的結果工廠創建一個對應的實例
      provider = DbProviderFactories.GetFactory(providerName);

      //使用該實例就可以創建對應的connection,command和adapater對象了

      //調試的時候可以看到這幾個對象都變成了相應於數據庫類型的
      cnn = provider.CreateConnection();
      cnn.ConnectionString = ConfigurationManager.ConnectionStrings[1].ConnectionString;
      cmd = provider.CreateCommand();
      cmd.Connection = cnn;
    }

    //執行一次查詢,返回數據表

    public DataTable ExcuteQuery(string queryString)
    {
      DataTable result = new DataTable();
      DbDataAdapter adapter = provider.CreateDataAdapter();
      cmd.CommandType = CommandType.Text;
      cmd.CommandText = queryString;
      adapter.SelectCommand = cmd;
      try
      {
        cnn.Open();
        adapter.Fill(result);
      }
      catch
      {
        result = null;
      }
      finally
      {
        cnn.Close();
      }
      return result;

    }

以上只是簡單的應用,並沒有做比較高級的封裝,只供不知道的兄弟參考。

順便說說,上午看到那個兄弟的文章用swith case語句來實現不同的創建connection ,command 和adapater的方法,然後說是工廠方法的實現。其實這是完全錯誤的,工廠模式的提出就是為了避免這麼多swith case造成的麻煩。以後有時間我會把幾個常用的模式的提出原因和應用場合總結一下用C#做幾個例子給不清楚的兄弟貼出來的。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved