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

C#利用IDbDataAdapter/IDataReader實現(xiàn)通用數(shù)據(jù)集獲取

 更新時間:2024年11月04日 08:48:07   作者:初九之潛龍勿用  
這篇文章主要為大家詳細介紹了C#利用IDbDataAdapter/IDataReader實現(xiàn)通用數(shù)據(jù)集獲取的相關(guān)知識,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下

關(guān)于數(shù)據(jù)集

在.net 應(yīng)用中,與數(shù)據(jù)庫進行連接并查詢相關(guān)數(shù)據(jù),填充到數(shù)據(jù)集是我們經(jīng)常用到的功能,數(shù)據(jù)集的表現(xiàn)形式基本包括如下:

1、 DataSet

DataSet 是 ADO.NET 中的數(shù)據(jù)集合對象,可以通過 IDbDataAdapter 接口對象,其表示一組與命令有關(guān)的屬性,用于填充 DataSet 和更新數(shù)據(jù)源。DataSet 相當于內(nèi)存中的數(shù)據(jù)庫,可以容納復(fù)雜關(guān)系的數(shù)據(jù),而且即使斷開數(shù)據(jù)鏈路,依然可以繼續(xù)獨立的操作。生成的 DataSet 由一組 DataTable 對象組成,即數(shù)據(jù)表集合。

2、 DataReader

DataReader 也是數(shù)據(jù)集的一種形式,它與 DataSet 的區(qū)別在于,其只允許以只讀、順序向下的方式查看其中所存儲的數(shù)據(jù),高效和簡單,是一種非常節(jié)省資源的數(shù)據(jù)對象,如果我們不考慮后續(xù)操作,只是顯示數(shù)據(jù),則 DataReader 對象幾乎是首選。

生成數(shù)據(jù)集對象需要利用 ADO.NET 中的數(shù)據(jù)提供者對象包括IDbConnection、IDbCommand、IDbDataParameter等,如何使用這些對象請參考我的文章:

《C#實現(xiàn) IDbConnection / IDbCommand 等相關(guān)通用數(shù)據(jù)接口》

本文將介紹如何通過利用IDbDataAdapter / IDataReader 實現(xiàn)通用數(shù)據(jù)集獲取。

獲取數(shù)據(jù)集的執(zhí)行流程

首先需要創(chuàng)建連接對象,成功后下達符合對應(yīng)數(shù)據(jù)庫規(guī)范的命令指令,該指令可能包括需要的參數(shù)對象(需要定義名稱和賦值等操作),通過數(shù)據(jù)適配器 IDbDataAdapter 接口對象填充到DataSet或通過命令對象() ExecuteReader 填充到 DataReader,大體流程如下圖:

范例運行環(huán)境

操作系統(tǒng): Windows Server 2019 DataCenter

.net版本: .netFramework4.7.1 或以上

開發(fā)工具:VS2019  C#

數(shù)據(jù)庫:在這里我們以支持 Oracle 9i、MS SQL Server 2016、國產(chǎn)達夢數(shù)據(jù) 8 為例

通用對象的設(shè)計與實現(xiàn)

引用

在實現(xiàn)方法前請引用如下代碼:

using System.Data;
using System.Data.SqlClient;
using System.Data.OracleClient;
using Dm;
using System.Collections;

GetDataAdapter方法

GetDataAdapter 方法返回 System.Data.IDbDataAdapter 數(shù)據(jù)適配器對象,其參數(shù)說明見下表:

序號參數(shù)名類型說明
1dbServerTypestring目前支持 "oracle"、 "dm8",其它字符串均視為 MS SQL Server

實現(xiàn)代碼如下:

public System.Data.IDbDataAdapter GetDataAdapter(string dbservertype)
{
    IDbDataAdapter adp = null;
    switch (dbservertype.ToLower())
    {
        case "oracle": adp =new OracleDataAdapter(); break;
        case "dm8": adp = new  DmDataAdapter(); break;
        default: adp =new SqlDataAdapter(); break;
    }
    return adp;
}

獲取數(shù)據(jù)集的設(shè)計與實現(xiàn)

GetDataSet方法

GetDataSet 方法返回 object 對象,如果生成成功則返回 DataSet 對象,失敗則返回錯誤信息字符串,其參數(shù)說明見下表:

序號參數(shù)名類型說明
1DbServerTypestring目前支持 "oracle"、 "dm8",其它字符串均視為 MS SQL Server
2strConnstring對應(yīng)數(shù)據(jù)庫的連接字符串
3_sqlstring要執(zhí)行的SQL語句命令行
4parasArrayList要賦值的參數(shù)對象,逐個添加到ArrayList里,請注意參數(shù)為實體數(shù)據(jù)參數(shù)對象,如 MS SQL Server ,請傳遞如下代碼:
ArrayList.Add(new SqlParameter("參數(shù)名",參數(shù)值)); 
5ctCommandTypeSystem.Data.CommandType 枚舉,可包括:
StoredProcedure(存儲過程)
TableDirect(直接表查詢)
Text(文本查詢)該值為默認值

有關(guān) CommandType 的更多資料請參考如下鏈接:

https://learn.microsoft.com/zh-CN/dotnet/api/system.data.commandtype

實現(xiàn)代碼如下:

public object GetDataSet(string DbServerType,string strConn,string _sql,ArrayList paras,CommandType ct)
{
            System.Data.IDbConnection Conn=GetConnection(DbServerType,strConn);
            System.Data.IDbCommand Cmd=GetCommand(DbServerType,_sql,paras,Conn);
            Cmd.CommandType=ct;
            DataSet ds=new DataSet();
            try
            {
                ds.EnforceConstraints=false;
                Conn.Open();
                System.Data.IDbDataAdapter adp=GetDataAdapter(DbServerType);
                adp.SelectCommand=Cmd;
                
                adp.FillSchema(ds,System.Data.SchemaType.Mapped);
                adp.Fill(ds);
                return ds;
            }
            catch (Exception e)
            {
                return e.Message;
            }
            finally
            {
                if(Conn.State==ConnectionState.Open)
                {
                    Conn.Close();
                }
            }
}

GetReaderData方法

GetReaderData 方法返回 IDataReader 對象,其參數(shù)說明見下表:

序號參數(shù)名類型說明
1DbServerTypestring目前支持 "oracle"、 "dm8",其它字符串均視為 MS SQL Server
2strConnstring對應(yīng)數(shù)據(jù)庫的連接字符串
3_sqlstring要執(zhí)行的SQL語句命令行
4parasArrayList 要賦值的參數(shù)對象,逐個添加到ArrayList里,請注意參數(shù)為實體數(shù)據(jù)參數(shù)對象,如 MS SQL Server ,請傳遞如下代碼:
ArrayList.Add(new SqlParameter("參數(shù)名",參數(shù)值)); 
5ctCommandTypeSystem.Data.CommandType 枚舉,可包括:
StoredProcedure(存儲過程)
TableDirect(直接表查詢)
Text(文本查詢)該值為默認值

有關(guān) CommandType 的更多資料請參考如下鏈接:

https://learn.microsoft.com/zh-CN/dotnet/api/system.data.commandtype

實現(xiàn)代碼如下:

public System.Data.IDataReader GetDataReader2(string DbServerType,string strConn,string _sql, ArrayList paras, CommandType ct)
{
      System.Data.IDbConnection Conn = GetConnection(DbServerType, strConn);
      System.Data.IDbCommand Cmd = GetCommand(DbServerType, _sql, paras, Conn);
      Cmd.CommandType = ct;
      Cmd.Connection = Conn;
      Conn.Open();
      return Cmd.ExecuteReader();
 
}

小結(jié)

有關(guān)更多關(guān)于數(shù)據(jù)接口對象請參考如下鏈接:

https://learn.microsoft.com/zh-CN/dotnet/api/system.data.idataadapter?view=netcore-3.1

IDbConnection 接口 (Microsoft.ReportingServices.DataProcessing) | Microsoft Learn

IDbConnection 接口 (Microsoft.ReportingServices.DataProcessing) | Microsoft Learn

到此這篇關(guān)于C#利用IDbDataAdapter/IDataReader實現(xiàn)通用數(shù)據(jù)集獲取的文章就介紹到這了,更多相關(guān)C#通用數(shù)據(jù)集獲取內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C#生成圖形驗證碼的實現(xiàn)方式

    C#生成圖形驗證碼的實現(xiàn)方式

    我們當用戶登錄系統(tǒng)時經(jīng)常會用到圖形驗證碼技術(shù),要求用戶識別圖片中的內(nèi)容,并正確輸入,方可嘗試登錄,因此,圖形驗證碼是一個網(wǎng)絡(luò)安全技術(shù)手段,圖形驗證碼的呈現(xiàn)形式有很多種,這里我們將介紹最基本的生成方式,感興趣的朋友可以參考下
    2024-04-04
  • C#實現(xiàn)將CSV轉(zhuǎn)為XLSX文件

    C#實現(xiàn)將CSV轉(zhuǎn)為XLSX文件

    Microsoft?Excel的XLSX格式以及基于文本的CSV(逗號分隔值)格式,是數(shù)據(jù)交換中常見的文件格式,本文主要介紹了如何在C#中以編程的方式將CSV文件轉(zhuǎn)化為XLSX?文件,需要的可以參考下
    2024-03-03
  • C#使用Newtonsoft.Json中的JObject對象

    C#使用Newtonsoft.Json中的JObject對象

    本文詳細講解了C#使用Newtonsoft.Json中JObject對象的方法,文中通過示例代碼介紹的非常詳細。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-07-07
  • C#調(diào)用Java代碼的方法介紹

    C#調(diào)用Java代碼的方法介紹

    這篇文章介紹了C#調(diào)用Java代碼的方法,有需要的朋友可以參考一下
    2013-10-10
  • C#關(guān)于反射加載的問題

    C#關(guān)于反射加載的問題

    C#關(guān)于反射加載的問題,需要的朋友可以參考下。
    2011-07-07
  • 淺談C#中ToString()和Convert.ToString()的區(qū)別

    淺談C#中ToString()和Convert.ToString()的區(qū)別

    本文介紹了ToString()和Convert.ToString()的使用方法,他們之間的區(qū)別,以及從object到string的轉(zhuǎn)換方法,希望對學(xué)習(xí)C#編程的你有所幫助
    2016-11-11
  • C#在foreach遍歷刪除集合中元素的三種實現(xiàn)方法

    C#在foreach遍歷刪除集合中元素的三種實現(xiàn)方法

    這篇文章主要給大家總結(jié)介紹了關(guān)于C#在foreach遍歷刪除集合中元素的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細,對大家學(xué)習(xí)或者使用C#具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-12-12
  • Json操作庫DynamicJson使用指南

    Json操作庫DynamicJson使用指南

    本文給大家分享的是專門為.NET程序員開發(fā)的Json操作庫DynamicJson,其源碼非常簡單,僅僅只有400行代碼,一個對應(yīng)的class類,目前只支持.NET 4.0以上的.NET Framework。
    2016-09-09
  • C#值類型、引用類型中的Equals和==的區(qū)別淺析

    C#值類型、引用類型中的Equals和==的區(qū)別淺析

    這篇文章主要介紹了C#值類型、引用類型中的Equals和==的區(qū)別淺析,本文分別對C#值類型和引用類型中的Equals和==做了講解和給出了實例,需要的朋友可以參考下
    2015-01-01
  • VS2019配置OpenCV4.1.0詳細教程與測試代碼(推薦)

    VS2019配置OpenCV4.1.0詳細教程與測試代碼(推薦)

    這篇文章主要介紹了VS2019配置OpenCV4.1.0詳細教程與測試代碼,本文通過截圖實例代碼相結(jié)合給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-03-03

最新評論