中文字幕在线观看,亚洲а∨天堂久久精品9966,亚洲成a人片在线观看你懂的,亚洲av成人片无码网站,亚洲国产精品无码久久久五月天

C#操作SQLite的輔助類

2018-07-20    來(lái)源:open-open

容器云強(qiáng)勢(shì)上線!快速搭建集群,上萬(wàn)Linux鏡像隨意使用
SQLite這個(gè)精巧的小數(shù)據(jù)庫(kù),無(wú)需安裝軟件,只需要一個(gè)System.Data.SQLite.DLL文件即可操作SQLite數(shù)據(jù)庫(kù)。SQLite是 一個(gè)開(kāi)源數(shù)據(jù)庫(kù),現(xiàn)在已變得越來(lái)越流行,它的體積很小,被廣泛應(yīng)用于各種不同類型的應(yīng)用中。
 
using System;
  
using System.Collections.Generic;
  
using System.Text;
  
using System.Web;
  
using System.Configuration;
  
using System.Data;
  
using System.Data.SQLite;
  
  
  
namespace DAL
  
{
  
    public class Sqlite
  
    {
  
        /// <summary>
  
        /// 獲得連接對(duì)象
  
        /// </summary>
  
        /// <returns></returns>
  
        public static SQLiteConnection GetSQLiteConnection()
  
        {
  
            return new SQLiteConnection("Data Source=" + System.Web.HttpContext.Current.Server.MapPath(System.Configuration.ConfigurationManager.AppSettings["db"].ToString()));
  
        }
  
  
  
        private static void PrepareCommand(SQLiteCommand cmd, SQLiteConnection conn, string cmdText, params object[] p)
  
        {
  
  
  
            if (conn.State != ConnectionState.Open)
  
                conn.Open();
  
            cmd.Parameters.Clear();
  
            cmd.Connection = conn;
  
            cmd.CommandText = cmdText;
  
  
  
            cmd.CommandType = CommandType.Text;
  
            cmd.CommandTimeout = 30;
  
  
  
            if (p != null)
  
            {
  
                foreach (object parm in p)
  
                    cmd.Parameters.AddWithValue(string.Empty, parm);
  
                //for (int i = 0; i < p.Length; i++)
  
                //    cmd.Parameters[i].Value = p[i];
  
            }
  
        }
  
  
  
        public static DataSet ExecuteDataset(string cmdText, params object[] p)
  
        {
  
            DataSet ds = new DataSet();
  
            SQLiteCommand command = new SQLiteCommand();
  
            using (SQLiteConnection connection = GetSQLiteConnection())
  
            {
  
                PrepareCommand(command, connection, cmdText, p);
  
                SQLiteDataAdapter da = new SQLiteDataAdapter(command);
  
                da.Fill(ds);
  
            }
  
  
  
            return ds;
  
        }
  
  
  
        public static DataRow ExecuteDataRow(string cmdText, params object[] p)
  
        {
  
            DataSet ds = ExecuteDataset(cmdText, p);
  
            if (ds != null && ds.Tables.Count > 0 && ds.Tables[0].Rows.Count > 0)
  
                return ds.Tables[0].Rows[0];
  
            return null;
  
        }
  
  
  
        /// <summary>
  
        /// 返回受影響的行數(shù)
  
        /// </summary>
  
        /// <param name="cmdText">a</param>
  
        /// <param name="commandParameters">傳入的參數(shù)</param>
  
        /// <returns></returns>
  
        public static int ExecuteNonQuery(string cmdText, params object[] p)
  
        {
  
            SQLiteCommand command = new SQLiteCommand();
  
  
  
            using (SQLiteConnection connection = GetSQLiteConnection())
  
            {
  
                PrepareCommand(command, connection, cmdText, p);
  
                return command.ExecuteNonQuery();
  
            }
  
        }
  
  
  
        /// <summary>
  
        /// 返回SqlDataReader對(duì)象
  
        /// </summary>
  
        /// <param name="cmdText"></param>
  
        /// <param name="commandParameters">傳入的參數(shù)</param>
  
        /// <returns></returns>
  
        public static SQLiteDataReader ExecuteReader(string cmdText, params object[] p)
  
        {
  
            SQLiteCommand command = new SQLiteCommand();
  
            SQLiteConnection connection = GetSQLiteConnection();
  
            try
  
            {
  
                PrepareCommand(command, connection, cmdText, p);
  
                SQLiteDataReader reader = command.ExecuteReader(CommandBehavior.CloseConnection);
  
                return reader;
  
            }
  
            catch
  
            {
  
                connection.Close();
  
                throw;
  
            }
  
        }
  
  
  
        /// <summary>
  
        /// 返回結(jié)果集中的第一行第一列,忽略其他行或列
  
        /// </summary>
  
        /// <param name="cmdText"></param>
  
        /// <param name="commandParameters">傳入的參數(shù)</param>
  
        /// <returns></returns>
  
        public static object ExecuteScalar(string cmdText, params object[] p)
  
        {
  
            SQLiteCommand cmd = new SQLiteCommand();
  
  
  
            using (SQLiteConnection connection = GetSQLiteConnection())
  
            {
  
                PrepareCommand(cmd, connection, cmdText, p);
  
                return cmd.ExecuteScalar();
  
            }
  
        }
  
  
  
        /// <summary>
  
        /// 分頁(yè)
  
        /// </summary>
  
        /// <param name="recordCount"></param>
  
        /// <param name="pageIndex"></param>
  
        /// <param name="pageSize"></param>
  
        /// <param name="cmdText"></param>
  
        /// <param name="countText"></param>
  
        /// <param name="p"></param>
  
        /// <returns></returns>
  
        public static DataSet ExecutePager(ref int recordCount, int pageIndex, int pageSize, string cmdText, string countText, params object[] p)
  
        {
  
            if (recordCount < 0)
  
                recordCount = int.Parse(ExecuteScalar(countText, p).ToString());
  
  
  
            DataSet ds = new DataSet();
  
  
  
            SQLiteCommand command = new SQLiteCommand();
  
            using (SQLiteConnection connection = GetSQLiteConnection())
  
            {
  
                PrepareCommand(command, connection, cmdText, p);
  
                SQLiteDataAdapter da = new SQLiteDataAdapter(command);
  
                da.Fill(ds, (pageIndex - 1) * pageSize, pageSize, "result");
  
            }
  
            return ds;
  
        }
  
    }
  
}
 

標(biāo)簽: 數(shù)據(jù)庫(kù)

版權(quán)申明:本站文章部分自網(wǎng)絡(luò),如有侵權(quán),請(qǐng)聯(lián)系:west999com@outlook.com
特別注意:本站所有轉(zhuǎn)載文章言論不代表本站觀點(diǎn)!
本站所提供的圖片等素材,版權(quán)歸原作者所有,如需使用,請(qǐng)與原作者聯(lián)系。

上一篇: php利用GD庫(kù)生成縮略圖

下一篇:UITextField限制輸入文字的個(gè)數(shù)