亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C# > 正文

C#實現的ACCESS數據庫操作類完整實例

2019-10-29 21:10:46
字體:
來源:轉載
供稿:網友

本文實例講述了C#實現的ACCESS數據庫操作類。分享給大家供大家參考,具體如下:

這個是針對ACCESS數據庫操作的類,同樣也是從SQLHELPER提取而來,分頁程序的調用可以參考MSSQL那個類的調用,差不多的,只是提取所有記錄的數量的時候有多一個參數,這個需要注意一下!

using System;using System.Text;using System.Collections;using System.Collections.Specialized;using System.Data;using System.Data.OleDb;using System.Configuration;namespace HoverTree.Web.DBUtility{  /// <summary>  /// 數據訪問抽象基礎類(ACCESS)  /// Copyright (C) 2006-2007 hovertree.net  /// All rights reserved  /// </summary>  public abstract class DbHelperACE  {    //數據庫連接字符串(web.config來配置)    //public static string connectionString = ConfigurationManager.AppSettings["ConnectionString"];    // public static string connectionString = System.Web.HttpContext.Current.Server.MapPath(ConfigurationManager.AppSettings["AccessConnectionString"]);    public static string connectionString = ConfigurationManager.AppSettings["AccessConnectionString"];    public DbHelperACE()    {    }    #region 公用方法    public static int GetMaxID(string FieldName, string TableName)    {      string strsql = "select max(" + FieldName + ")+1 from " + TableName;      object obj = DbHelperACE.GetSingle(strsql);      if (obj == null)      {        return 1;      }      else      {        return int.Parse(obj.ToString());      }    }    public static bool Exists(string strSql)    {      object obj = DbHelperACE.GetSingle(strSql);      int cmdresult;      if ((Object.Equals(obj, null)) || (Object.Equals(obj, System.DBNull.Value)))      {        cmdresult = 0;      }      else      {        cmdresult = int.Parse(obj.ToString());      }      if (cmdresult == 0)      {        return false;      }      else      {        return true;      }    }    public static bool Exists(string strSql, params OleDbParameter[] cmdParms)    {      object obj = DbHelperACE.GetSingle(strSql, cmdParms);      int cmdresult;      if ((Object.Equals(obj, null)) || (Object.Equals(obj, System.DBNull.Value)))      {        cmdresult = 0;      }      else      {        cmdresult = int.Parse(obj.ToString());      }      if (cmdresult == 0)      {        return false;      }      else      {        return true;      }    }    #endregion    #region 執行簡單SQL語句    /// <summary>    /// 執行SQL語句,返回影響的記錄數    /// </summary>    /// <param name="SQLString">SQL語句</param>    /// <returns>影響的記錄數</returns>    public static int ExecuteSql(string SQLString)    {      using (OleDbConnection connection = new OleDbConnection(connectionString))      {        using (OleDbCommand cmd = new OleDbCommand(SQLString, connection))        {          try          {            connection.Open();            int rows = cmd.ExecuteNonQuery();            return rows;          }          catch (System.Data.OleDb.OleDbException E)          {            connection.Close();            throw new Exception(E.Message);          }        }      }    }    /// <summary>    /// 執行SQL語句,設置命令的執行等待時間    /// </summary>    /// <param name="SQLString"></param>    /// <param name="Times"></param>    /// <returns></returns>    public static int ExecuteSqlByTime(string SQLString, int Times)    {      using (OleDbConnection connection = new OleDbConnection(connectionString))      {        using (OleDbCommand cmd = new OleDbCommand(SQLString, connection))        {          try          {            connection.Open();            cmd.CommandTimeout = Times;            int rows = cmd.ExecuteNonQuery();            return rows;          }          catch (System.Data.OleDb.OleDbException E)          {            connection.Close();            throw new Exception(E.Message);          }        }      }    }    /// <summary>    /// 執行多條SQL語句,實現數據庫事務。    /// </summary>    /// <param name="SQLStringList">多條SQL語句</param>    public static void ExecuteSqlTran(ArrayList SQLStringList)    {      using (OleDbConnection conn = new OleDbConnection(connectionString))      {        conn.Open();        OleDbCommand cmd = new OleDbCommand();        cmd.Connection = conn;        OleDbTransaction tx = conn.BeginTransaction();        cmd.Transaction = tx;        try        {          for (int n = 0; n < SQLStringList.Count; n++)          {            string strsql = SQLStringList[n].ToString();            if (strsql.Trim().Length > 1)            {              cmd.CommandText = strsql;              cmd.ExecuteNonQuery();            }          }          tx.Commit();        }        catch (System.Data.OleDb.OleDbException E)        {          tx.Rollback();          throw new Exception(E.Message);        }      }    }    /// <summary>    /// 向數據庫里插入圖像格式的字段(和上面情況類似的另一種實例)    /// </summary>    /// <param name="strSQL">SQL語句</param>    /// <param name="fs">圖像字節,數據庫的字段類型為image的情況</param>    /// <returns>影響的記錄數</returns>    public static int ExecuteSqlInsertImg(string strSQL, byte[] fs)    {      using (OleDbConnection connection = new OleDbConnection(connectionString))      {        OleDbCommand cmd = new OleDbCommand(strSQL, connection);        System.Data.OleDb.OleDbParameter myParameter = new System.Data.OleDb.OleDbParameter("@fs", SqlDbType.Image);        myParameter.Value = fs;        cmd.Parameters.Add(myParameter);        try        {          connection.Open();          int rows = cmd.ExecuteNonQuery();          return rows;        }        catch (System.Data.OleDb.OleDbException E)        {          throw new Exception(E.Message);        }        finally        {          cmd.Dispose();          connection.Close();        }      }    }    /// <summary>    /// 執行一條計算查詢結果語句,返回查詢結果(object)。    /// </summary>    /// <param name="SQLString">計算查詢結果語句</param>    /// <returns>查詢結果(object)</returns>    public static object GetSingle(string SQLString)    {      using (OleDbConnection connection = new OleDbConnection(connectionString))      {        using (OleDbCommand cmd = new OleDbCommand(SQLString, connection))        {          try          {            connection.Open();            object obj = cmd.ExecuteScalar();            if ((Object.Equals(obj, null)) || (Object.Equals(obj, System.DBNull.Value)))            {              return null;            }            else            {              return obj;            }          }          catch (System.Data.OleDb.OleDbException e)          {            connection.Close();            throw new Exception(e.Message);          }        }      }    }    /// <summary>    /// 執行查詢語句,返回SqlDataReader(使用該方法切記要手工關閉SqlDataReader和連接)    /// </summary>    /// <param name="strSQL">查詢語句</param>    /// <returns>SqlDataReader</returns>    public static OleDbDataReader ExecuteReader(string strSQL)    {      OleDbConnection connection = new OleDbConnection(connectionString);      OleDbCommand cmd = new OleDbCommand(strSQL, connection);      try      {        connection.Open();        OleDbDataReader myReader = cmd.ExecuteReader();        return myReader;      }      catch (System.Data.OleDb.OleDbException e)      {        throw new Exception(e.Message);      }      //finally //不能在此關閉,否則,返回的對象將無法使用      //{      // cmd.Dispose();      // connection.Close();      //}    }    /// <summary>    /// 執行查詢語句,返回DataSet    /// </summary>    /// <param name="SQLString">查詢語句</param>    /// <returns>DataSet</returns>    public static DataSet Query(string SQLString)    {      using (OleDbConnection connection = new OleDbConnection(connectionString))      {        DataSet ds = new DataSet();        try        {          connection.Open();          OleDbDataAdapter command = new OleDbDataAdapter(SQLString, connection);          command.Fill(ds, "ds");        }        catch (System.Data.OleDb.OleDbException ex)        {          throw new Exception(ex.Message);        }        return ds;      }    }    /// <summary>    /// 執行查詢語句,返回DataSet,設置命令的執行等待時間    /// </summary>    /// <param name="SQLString"></param>    /// <param name="Times"></param>    /// <returns></returns>    public static DataSet Query(string SQLString, int Times)    {      using (OleDbConnection connection = new OleDbConnection(connectionString))      {        DataSet ds = new DataSet();        try        {          connection.Open();          OleDbDataAdapter command = new OleDbDataAdapter(SQLString, connection);          command.SelectCommand.CommandTimeout = Times;          command.Fill(ds, "ds");        }        catch (System.Data.OleDb.OleDbException ex)        {          throw new Exception(ex.Message);        }        return ds;      }    }    #endregion    #region 執行帶參數的SQL語句    /// <summary>    /// 執行SQL語句,返回影響的記錄數    /// </summary>    /// <param name="SQLString">SQL語句</param>    /// <returns>影響的記錄數</returns>    public static int ExecuteSql(string SQLString, params OleDbParameter[] cmdParms)    {      using (OleDbConnection connection = new OleDbConnection(connectionString))      {        using (OleDbCommand cmd = new OleDbCommand())        {          try          {            PrepareCommand(cmd, connection, null, SQLString, cmdParms);            int rows = cmd.ExecuteNonQuery();            cmd.Parameters.Clear();            return rows;          }          catch (System.Data.OleDb.OleDbException E)          {            throw new Exception(E.Message);          }        }      }    }    /// <summary>    /// 執行多條SQL語句,實現數據庫事務。    /// </summary>    /// <param name="SQLStringList">SQL語句的哈希表(key為sql語句,value是該語句的OleDbParameter[])</param>    public static void ExecuteSqlTran(Hashtable SQLStringList)    {      using (OleDbConnection conn = new OleDbConnection(connectionString))      {        conn.Open();        using (OleDbTransaction trans = conn.BeginTransaction())        {          OleDbCommand cmd = new OleDbCommand();          try          {            //循環            foreach (DictionaryEntry myDE in SQLStringList)            {              string cmdText = myDE.Key.ToString();              OleDbParameter[] cmdParms = (OleDbParameter[])myDE.Value;              PrepareCommand(cmd, conn, trans, cmdText, cmdParms);              int val = cmd.ExecuteNonQuery();              cmd.Parameters.Clear();              trans.Commit();            }          }          catch          {            trans.Rollback();            throw;          }        }      }    }    /// <summary>    /// 執行一條計算查詢結果語句,返回查詢結果(object)。    /// </summary>    /// <param name="SQLString">計算查詢結果語句</param>    /// <returns>查詢結果(object)</returns>    public static object GetSingle(string SQLString, params OleDbParameter[] cmdParms)    {      using (OleDbConnection connection = new OleDbConnection(connectionString))      {        using (OleDbCommand cmd = new OleDbCommand())        {          try          {            PrepareCommand(cmd, connection, null, SQLString, cmdParms);            object obj = cmd.ExecuteScalar();            cmd.Parameters.Clear();            if ((Object.Equals(obj, null)) || (Object.Equals(obj, System.DBNull.Value)))            {              return null;            }            else            {              return obj;            }          }          catch (System.Data.OleDb.OleDbException e)          {            throw new Exception(e.Message);          }        }      }    }      /// <summary>    /// 執行查詢語句,返回SqlDataReader (使用該方法切記要手工關閉SqlDataReader和連接)    /// </summary>    /// <param name="strSQL">查詢語句</param>    /// <returns>SqlDataReader</returns>    public static OleDbDataReader ExecuteReader(string SQLString, params OleDbParameter[] cmdParms)    {      OleDbConnection connection = new OleDbConnection(connectionString);      OleDbCommand cmd = new OleDbCommand();      try      {        PrepareCommand(cmd, connection, null, SQLString, cmdParms);        OleDbDataReader myReader = cmd.ExecuteReader();        cmd.Parameters.Clear();        return myReader;      }      catch (System.Data.OleDb.OleDbException e)      {        throw new Exception(e.Message);      }      //finally //不能在此關閉,否則,返回的對象將無法使用      //{      // cmd.Dispose();      // connection.Close();      //}    }    /// <summary>    /// 執行查詢語句,返回DataSet    /// </summary>    /// <param name="SQLString">查詢語句</param>    /// <returns>DataSet</returns>    public static DataSet Query(string SQLString, params OleDbParameter[] cmdParms)    {      using (OleDbConnection connection = new OleDbConnection(connectionString))      {        OleDbCommand cmd = new OleDbCommand();        PrepareCommand(cmd, connection, null, SQLString, cmdParms);        using (OleDbDataAdapter da = new OleDbDataAdapter(cmd))        {          DataSet ds = new DataSet();          try          {            da.Fill(ds, "ds");            cmd.Parameters.Clear();          }          catch (System.Data.OleDb.OleDbException ex)          {            throw new Exception(ex.Message);          }          return ds;        }      }    }    private static void PrepareCommand(OleDbCommand cmd, OleDbConnection conn, OleDbTransaction trans, string cmdText, OleDbParameter[] cmdParms)    {      if (conn.State != ConnectionState.Open)        conn.Open();      cmd.Connection = conn;      cmd.CommandText = cmdText;      if (trans != null)        cmd.Transaction = trans;      cmd.CommandType = CommandType.Text;//cmdType;      if (cmdParms != null)      {        foreach (OleDbParameter parameter in cmdParms)        {          if ((parameter.Direction == ParameterDirection.InputOutput || parameter.Direction == ParameterDirection.Input) &&            (parameter.Value == null))          {            parameter.Value = DBNull.Value;          }          cmd.Parameters.Add(parameter);        }      }    }    #endregion    #region 獲取根據指定字段排序并分頁查詢。        /// <summary>    /// 分頁查詢數據記錄總數獲取    /// </summary>    /// <param name="_tbName">----要顯示的表或多個表的連接</param>    /// <param name="_ID">----主表的主鍵</param>    /// <param name="_strCondition">----查詢條件,不需where</param>    /// <param name="_Dist">----是否添加查詢字段的 DISTINCT 默認0不添加/1添加</param>    /// <returns></returns>    public static string getPageListCounts(string _ID, string _tbName, string _strCondition, int _Dist)    {      //---存放取得查詢結果總數的查詢語句      //---對含有DISTINCT的查詢進行SQL構造      //---對含有DISTINCT的總數查詢進行SQL構造      string strTmp = "", SqlSelect = "", SqlCounts = "";      if (_Dist == 0)      {        SqlSelect = "Select ";        SqlCounts = "COUNT(*)";      }      else      {        SqlSelect = "Select DISTINCT ";        SqlCounts = "COUNT(DISTINCT " + _ID + ")";      }      if (_strCondition == string.Empty)      {        strTmp = SqlSelect + " "+ SqlCounts + " FROM " + _tbName;      }      else      {        strTmp = SqlSelect + " "+ SqlCounts + " FROM " + " Where (1=1) " + _strCondition;      }      return strTmp;    }    /// <summary>    /// 智能返回SQL語句    /// </summary>    /// <param name="primaryKey">主鍵(不能為空)</param>    /// <param name="queryFields">提取字段(不能為空)</param>    /// <param name="tableName">表(理論上允許多表)</param>    /// <param name="condition">條件(可以空)</param>    /// <param name="OrderBy">排序,格式:字段名+""+ASC(可以空)</param>    /// <param name="pageSize">分頁數(不能為空)</param>    /// <param name="pageIndex">當前頁,起始為:1(不能為空)</param>    /// <returns></returns>    public static string getPageListSql(string primaryKey, string queryFields, string tableName, string condition, string orderBy, int pageSize, int pageIndex)    {      string strTmp = ""; //---strTmp用于返回的SQL語句      string SqlSelect = "", SqlPrimaryKeySelect = "", strOrderBy = "", strWhere = " where 1=1 ", strTop = "";      //0:分頁數量      //1:提取字段      //2:表      //3:條件      //4:主鍵不存在的記錄      //5:排序      SqlSelect = " select top {0} {1} from {2} {3} {4} {5}";      //0:主鍵      //1:TOP數量,為分頁數*(排序號-1)      //2:表      //3:條件      //4:排序      SqlPrimaryKeySelect = " and {0} not in (select {1} {0} from {2} {3} {4}) ";      if (orderBy != "")        strOrderBy = " order by " + orderBy;      if (condition != "")        strWhere += " and " + condition;      int pageindexsize = (pageIndex - 1) * pageSize;      if (pageindexsize > 0)      {        strTop = " top " + pageindexsize.ToString();        SqlPrimaryKeySelect = String.Format(SqlPrimaryKeySelect, primaryKey, strTop, tableName, strWhere, strOrderBy);        strTmp = String.Format(SqlSelect, pageSize.ToString(), queryFields, tableName, strWhere, SqlPrimaryKeySelect, strOrderBy);      }      else      {        strTmp = String.Format(SqlSelect, pageSize.ToString(), queryFields, tableName, strWhere, "", strOrderBy);      }      return strTmp;    }    /// <summary>    /// 獲取根據指定字段排序并分頁查詢。DataSet    /// </summary>    /// <param name="pageSize">每頁要顯示的記錄的數目</param>    /// <param name="pageIndex">要顯示的頁的索引</param>    /// <param name="tableName">要查詢的數據表</param>    /// <param name="queryFields">要查詢的字段,如果是全部字段請填寫:*</param>    /// <param name="primaryKey">主鍵字段,類似排序用到</param>    /// <param name="orderBy">是否為升序排列:0為升序,1為降序</param>    /// <param name="condition">查詢的篩選條件</param>    /// <returns>返回排序并分頁查詢的DataSet</returns>    public static DataSet GetPagingList(string primaryKey, string queryFields, string tableName, string condition, string orderBy, int pageSize, int pageIndex)    {      string sql = getPageListSql(primaryKey, queryFields, tableName, condition, orderBy, pageSize, pageIndex);      return Query(sql);    }    public static string GetPagingListSQL(string primaryKey, string queryFields, string tableName, string condition, string orderBy, int pageSize, int pageIndex)    {      string sql = getPageListSql(primaryKey, queryFields, tableName, condition, orderBy, pageSize, pageIndex);      return sql;    }    public static int GetRecordCount(string _ID, string _tbName, string _strCondition, int _Dist)    {      string sql = getPageListCounts( _ID, _tbName, _strCondition, _Dist);      object obj = DbHelperACE.GetSingle(sql);      if (obj == null)      {        return 1;      }      else      {        return int.Parse(obj.ToString());      }    }    #endregion  }}

希望本文所述對大家C#程序設計有所幫助。


注:相關教程知識閱讀請移步到c#教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
美日韩在线视频| 国产精品视频中文字幕91| 青草热久免费精品视频| 亚洲伊人久久大香线蕉av| 国产精品wwwwww| 欧美视频第一页| 97在线观看视频国产| 日韩美女免费视频| 欧美日韩在线观看视频小说| 久久人人爽亚洲精品天堂| 色综合天天综合网国产成人网| 91免费福利视频| 欧美成人激情视频| 亚洲色图色老头| 影音先锋日韩有码| xxxx欧美18另类的高清| 中文字幕日韩有码| 日韩有码片在线观看| 国产精品99一区| 国产精品啪视频| 国产成人+综合亚洲+天堂| 国产欧亚日韩视频| 国产香蕉一区二区三区在线视频| 亚洲欧美在线磁力| 欧美大片在线影院| 欧美xxxx18国产| 亚洲激情中文字幕| 亚洲性生活视频在线观看| 清纯唯美亚洲激情| 国产精品午夜国产小视频| 久久影院资源站| 97视频在线观看视频免费视频| 国产精品精品久久久久久| 久久久精品亚洲| 国产在线精品播放| 全球成人中文在线| 国产精品免费福利| 亚洲欧美精品一区| 91社影院在线观看| 国产精品xxx视频| 亚洲欧美日韩一区二区三区在线| 91精品国产91久久久| 欧美成人三级视频网站| 国产不卡av在线免费观看| 亚洲高清久久网| 欧美成在线视频| 日韩中文在线视频| 亚洲天堂色网站| 成人a视频在线观看| 国产一区二区三区直播精品电影| 精品欧美一区二区三区| 91午夜在线播放| 亚洲伊人一本大道中文字幕| 精品国产乱码久久久久久虫虫漫画| 成人欧美在线视频| 亚洲欧美日韩国产中文| 久久成人精品电影| 亚洲男人天堂视频| 一二美女精品欧洲| 91精品国产综合久久香蕉最新版| 最近中文字幕mv在线一区二区三区四区| 欧美日韩精品国产| 97在线免费观看视频| 亚洲综合中文字幕在线观看| 亚洲欧洲在线观看| 欧美午夜精品在线| 久久精品亚洲94久久精品| 国产成人精品在线播放| 26uuu另类亚洲欧美日本一| 日本精品va在线观看| 91精品国产综合久久香蕉922| 久久久人成影片一区二区三区观看| 久久久久久亚洲| 日韩成人在线播放| 九九精品视频在线| 欧美电影第一页| 精品无人区乱码1区2区3区在线| 在线观看日韩专区| 国产精品一区专区欧美日韩| 原创国产精品91| 亚洲精品久久久久| 国产91精品网站| 欧美激情亚洲激情| 777午夜精品福利在线观看| 国产精品高清网站| 国产精品专区一| 国产日韩欧美自拍| 日韩高清电影免费观看完整| 97国产真实伦对白精彩视频8| 国产精品成人一区二区三区吃奶| 久久人人爽人人爽人人片av高请| 日韩一区二区在线视频| 久久久久久久国产精品| 亚洲精品一区二区久| 97香蕉久久夜色精品国产| 久久久久久噜噜噜久久久精品| 久久精品国产欧美激情| 91精品久久久久久久久久久久久久| 欧美日韩免费在线观看| 亚洲第一天堂av| 2019国产精品自在线拍国产不卡| 成人写真福利网| 91美女福利视频高清| 亚洲字幕在线观看| 国产精品十八以下禁看| 欧美精品久久久久久久久久| 激情av一区二区| 国内精品久久久久伊人av| 欧美专区国产专区| 久久久av一区| 热草久综合在线| 成人精品视频在线| 亚洲电影免费观看高清| 亚洲第一二三四五区| 欧美成aaa人片免费看| 亚洲永久在线观看| 日韩高清av一区二区三区| 欧美日韩成人在线观看| 日韩国产高清视频在线| 国产日韩欧美视频| 欧美激情一区二区三区高清视频| 不卡av电影在线观看| 日韩电影免费在线观看中文字幕| 亚洲男人的天堂在线播放| 亚洲第一天堂无码专区| 久久久99免费视频| 国产精品91视频| 欧美性xxxx| 欧美性猛交xxxx乱大交| 精品日韩中文字幕| 欧美大片在线影院| 国产成人a亚洲精品| 欧美激情视频播放| 自拍偷拍亚洲欧美| 午夜精品理论片| 欧美成人午夜剧场免费观看| 国产在线视频91| 欧美日韩另类在线| 在线观看国产精品91| 91精品在线观看视频| 日韩精品在线第一页| 91日本视频在线| 国产精品v日韩精品| 91精品视频在线免费观看| 岛国av一区二区三区| 亚洲aⅴ男人的天堂在线观看| 久久精品成人动漫| 久久久亚洲福利精品午夜| 欧美猛少妇色xxxxx| 综合网日日天干夜夜久久| 久久免费精品视频| 亚洲国产91色在线| 青草青草久热精品视频在线网站| 91国自产精品中文字幕亚洲| 亚洲第一网站男人都懂| 国产美女直播视频一区| 亚洲成人黄色网址| 日韩av在线一区| 亚洲天堂第一页| 欧美成人在线网站| 国产成人精品视| 91超碰中文字幕久久精品| 欧美人在线观看| 久久久国产精彩视频美女艺术照福利|