亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C#封裝DBHelper類

 更新時(shí)間:2022年05月04日 10:37:34   作者:農(nóng)碼一生  
DBHelper類是用類將ADO.NET用方法封裝起來,用以減少程序員的工作量。本文為大家提供一個(gè)C#封裝的DBHelper類,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

DBHelper從字面上理解為“數(shù)據(jù)庫幫助類”,由于持久層需要與數(shù)據(jù)庫進(jìn)行交互,因此每次交互的時(shí)候都會(huì)重復(fù)去加載驅(qū)動(dòng)、填寫數(shù)據(jù)庫連接信息、建立(獲取)數(shù)據(jù)庫連接、關(guān)閉數(shù)據(jù)庫,所以導(dǎo)致代碼中出現(xiàn)了大量的冗余代碼,因此把這些重復(fù)需要執(zhí)行的代碼抽取出來,就成了一個(gè)DBHelper,一個(gè)簡單的DBHelper提供了最基礎(chǔ)的數(shù)據(jù)庫初始化連接及驅(qū)動(dòng),提供了連接數(shù)據(jù)庫的API和關(guān)閉數(shù)據(jù)庫的API,通常的做法是把這些API做成靜態(tài)的,使用的時(shí)候直接通過 類.API 進(jìn)行調(diào)用,因此大量的簡化了代碼的書寫,提高了代碼的可維護(hù)性,同時(shí)也利于更換數(shù)據(jù)庫及驅(qū)動(dòng)。

詳細(xì)代碼:

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

namespace WindowsFormsApplication1
{
    class DBHelper
    {
        //SQL連接字符串-SQL身份認(rèn)證方式登錄
        public static string connStr = "server=.;database=DBTEST;uid=sa;pwd=123456;";

        //SQL連接字符串-Windows身份認(rèn)證方式登錄
        //public static string connStr = "Integrated Security=SSPI;Persist Security Info=False;Initial Catalog=DBTEST;Data Source=.";

        //讀取配置文件appSettings節(jié)點(diǎn)讀取字符串(需要添加引用System.Configuration)
        //public static string connStr = ConfigurationManager.AppSettings["DefaultConn"].ToString();
        //對(duì)應(yīng)的配置文件如下:
        //<appSettings>
        //  <add key="DefaultConn" value="Integrated Security=SSPI;Persist Security Info=False;Initial Catalog=DBTEST;Data Source=."/>
        //</appSettings>

        //讀取配置文件ConnectionStrings節(jié)點(diǎn)讀取字符串(需要添加引用System.Configuration)
        //public static string connStr = ConfigurationManager.ConnectionStrings["DefaultConn"].ConnectionString;
        //對(duì)應(yīng)配置文件如下:
        //<connectionStrings>
        //    <add name="DefaultConn" connectionString="Integrated Security=SSPI;Persist Security Info=False;Initial Catalog=DBTEST;Data Source=."/>
        //</connectionStrings>

        public static SqlConnection conn = null;
        public static SqlDataAdapter adp = null;

        #region 連接數(shù)據(jù)庫
        /// <summary>
        /// 連接數(shù)據(jù)庫
        /// </summary>
        public static void OpenConn()
        {
            if (conn == null)
            {
                conn = new SqlConnection(connStr);
                conn.Open();
            }
            if (conn.State == System.Data.ConnectionState.Closed)
            {
                conn.Open();
            }
            if (conn.State == System.Data.ConnectionState.Broken)
            {
                conn.Close();
                conn.Open();
            }
        }
        #endregion

        #region 執(zhí)行SQL語句前準(zhǔn)備
        /// <summary>
        /// 準(zhǔn)備執(zhí)行一個(gè)SQL語句
        /// </summary>
        /// <param name="sql">需要執(zhí)行的SQL語句</param>
        public static void PrepareSql(string sql)
        {
            OpenConn(); //打開數(shù)據(jù)庫連接
            adp = new SqlDataAdapter(sql, conn);
        }
        #endregion

        #region 設(shè)置和獲取sql語句的參數(shù)
        /// <summary>
        /// 設(shè)置傳入?yún)?shù)
        /// </summary>
        /// <param name="parameterName">參數(shù)名稱</param>
        /// <param name="parameterValue">參數(shù)值</param>
        public static void SetParameter(string parameterName, object parameterValue)
        {
            parameterName = "@" + parameterName.Trim();
            if (parameterValue == null)
                parameterValue = DBNull.Value;
            adp.SelectCommand.Parameters.Add(new SqlParameter(parameterName, parameterValue));
        }
        #endregion

        #region 執(zhí)行SQL語句
        /// <summary>
        /// 執(zhí)行非查詢SQL語句
        /// </summary>
        /// <returns>受影響行數(shù)</returns>
        public static int ExecNonQuery()
        {
            int result = adp.SelectCommand.ExecuteNonQuery();
            conn.Close();
            return result;
        }
        /// <summary>
        /// 執(zhí)行查詢SQL語句
        /// </summary>
        /// <returns>DataTable類型查詢結(jié)果</returns>
        public static DataTable ExecQuery()
        {
            DataTable dt = new DataTable();
            adp.Fill(dt);
            conn.Close();
            return dt;
        }
        /// <summary>
        /// 執(zhí)行查詢SQL語句
        /// </summary>
        /// <returns>SqlDataReader類型查詢結(jié)果,SqlDataReader需要手動(dòng)關(guān)閉</returns>
        public static SqlDataReader ExecDataReader()
        {
            return adp.SelectCommand.ExecuteReader(CommandBehavior.CloseConnection);
        }
        /// <summary>
        /// 執(zhí)行查詢SQL語句
        /// </summary>
        /// <returns>查詢結(jié)果第一行第一列</returns>
        public static object ExecScalar()
        {
            object obj = adp.SelectCommand.ExecuteScalar();
            conn.Close();
            return obj;
        }
        #endregion
    }
}

到此這篇關(guān)于C#封裝DBHelper類的文章就介紹到這了。希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • C#使用SqlConnection連接到SQL Server的代碼示例

    C#使用SqlConnection連接到SQL Server的代碼示例

    這篇文章主要介紹了C#使用SqlConnection連接到SQL Server的代碼示例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • C#實(shí)現(xiàn)多文件壓縮與解壓功能

    C#實(shí)現(xiàn)多文件壓縮與解壓功能

    這篇文章主要為大家詳細(xì)介紹了如何利用C#語言實(shí)現(xiàn)多文件壓縮與解壓功能,即選擇多個(gè)文件壓縮成ZIP文件和解壓ZIP文件,需要的可以參考一下
    2022-08-08
  • c# winform 解決PictureBox 無法打印全部圖片的問題

    c# winform 解決PictureBox 無法打印全部圖片的問題

    這篇文章主要介紹了c# winform 解決PictureBox 無法打印全部圖片的問題,幫助大家更好進(jìn)行c# winform開發(fā),感興趣的朋友可以了解下
    2020-12-12
  • Unity3D動(dòng)態(tài)生成平面網(wǎng)格

    Unity3D動(dòng)態(tài)生成平面網(wǎng)格

    這篇文章主要為大家詳細(xì)介紹了Unity3D動(dòng)態(tài)生成平面網(wǎng)格,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-02-02
  • C#中的虛函數(shù)virtual

    C#中的虛函數(shù)virtual

    這篇文章介紹了C#中的虛函數(shù)virtual,文中通過示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-04-04
  • c#創(chuàng)建windows服務(wù)(Windows Services)詳細(xì)步驟

    c#創(chuàng)建windows服務(wù)(Windows Services)詳細(xì)步驟

    這篇文章主要介紹了c#創(chuàng)建windows服務(wù)(Windows Services)詳細(xì)步驟,大家參考使用吧
    2013-12-12
  • c#委托把方法當(dāng)成參數(shù)(實(shí)例講解)

    c#委托把方法當(dāng)成參數(shù)(實(shí)例講解)

    本篇文章主要是對(duì)c#委托把方法當(dāng)成參數(shù)的實(shí)例代碼進(jìn)行了介紹,需要的朋友可以過來參考下,希望對(duì)大家有所幫助
    2014-01-01
  • C#設(shè)計(jì)模式之職責(zé)鏈模式示例詳解

    C#設(shè)計(jì)模式之職責(zé)鏈模式示例詳解

    這篇文章主要給大家介紹了關(guān)于C#設(shè)計(jì)模式之職責(zé)鏈模式的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • C#中的應(yīng)用程序接口介紹及實(shí)現(xiàn),密封類與密封方法

    C#中的應(yīng)用程序接口介紹及實(shí)現(xiàn),密封類與密封方法

    今天小編就為大家分享一篇關(guān)于C#中的應(yīng)用程序接口介紹及實(shí)現(xiàn),密封類與密封方法,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧
    2018-10-10
  • WPF實(shí)現(xiàn)半圓形導(dǎo)航菜單

    WPF實(shí)現(xiàn)半圓形導(dǎo)航菜單

    這篇文章主要為大家詳細(xì)介紹了WPF實(shí)現(xiàn)半圓形導(dǎo)航菜單,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-08-08

最新評(píng)論