加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

SQLite增删改查

发布时间:2020-12-12 20:05:46 所属栏目:百科 来源:网络整理
导读:原文:http://www.51aspx.com/CodeFile/WolfySQLiteDemo,22494/SQLiteHelper.cs.html dll文件:http://pan.baidu.com/s/1dDEGgZR public class SQLiteHelper { private static readonly string databaseName = AppDomain.CurrentDomain.BaseDirectory + Conf

原文:http://www.51aspx.com/CodeFile/WolfySQLiteDemo,22494/SQLiteHelper.cs.html

dll文件:http://pan.baidu.com/s/1dDEGgZR

 public class SQLiteHelper
    {
        private static readonly string databaseName = AppDomain.CurrentDomain.BaseDirectory + ConfigurationManager.AppSettings["databaseName"];
        /// <summary>
        /// 创建数据库
        /// </summary>
        /// <param name="databaseName">数据库文件路径</param>
        public static void CreateDataBase()
        {
            if (!File.Exists(databaseName))
            {
                SQLiteConnection.CreateFile(databaseName);
            }
        }
        /// <summary>
        /// 获得连接对象
        /// </summary>
        /// <returns></returns>
        public static SQLiteConnection GetSQLiteConnection()
        {
            #region 方法一
            SQLiteConnectionStringBuilder connStr = new SQLiteConnectionStringBuilder();
            connStr.DataSource = databaseName;
            connStr.Password = "123456";
            connStr.Pooling = true;
            return new SQLiteConnection(connStr.ToString());
            #endregion
            #region 方法二
            //return new SQLiteConnection(string.Format("Data Source={0};password=123456",databaseName));
            #endregion
        }
        /// <summary>
        /// 匹配参数
        /// </summary>
        /// <param name="cmd"></param>
        /// <param name="conn"></param>
        /// <param name="cmdText"></param>
        /// <param name="p"></param>
        private static void PrepareCommand(SQLiteCommand cmd,SQLiteConnection conn,string cmdText,params object[] p)
        {
            if (conn.State == System.Data.ConnectionState.Closed)
            {
                conn.Open();
            }
            cmd.Parameters.Clear();
            cmd.Connection = conn;
            cmd.CommandText = cmdText;
            cmd.CommandType = System.Data.CommandType.Text;
            cmd.CommandTimeout = 30;
            if (p != null)
            {
                foreach (object item in p)
                {
                    cmd.Parameters.AddWithValue(string.Empty,item);
                }
            }
        }
        /// <summary>
        /// 返回DataSet
        /// </summary>
        /// <param name="cmdText"></param>
        /// <param name="p"></param>
        /// <returns></returns>
        public static DataSet ExecuteDataset(string cmdText,params object[] p)
        {
            DataSet ds = new DataSet();
            SQLiteCommand cmd = new SQLiteCommand();
            using (SQLiteConnection conn = GetSQLiteConnection())
            {
                PrepareCommand(cmd,conn,cmdText,p);
                SQLiteDataAdapter sda = new SQLiteDataAdapter(cmd);
                sda.Fill(ds);
            }
            return ds;
        }
        /// <summary>
        /// 返回第一行
        /// </summary>
        /// <param name="cmdText"></param>
        /// <param name="p"></param>
        /// <returns></returns>
        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];
            }
            else
            {
                return null;
            }
        }
        /// <summary>
        /// 执行非查询操作 返回受影响的行数
        /// </summary>
        /// <param name="cmdText"></param>
        /// <param name="p"></param>
        /// <returns></returns>
        public static int ExecuteNonQuery(string cmdText,params object[] p)
        {
            SQLiteCommand cmd = new SQLiteCommand();
            using (SQLiteConnection conn = GetSQLiteConnection())
            {
                PrepareCommand(cmd,p);
                return cmd.ExecuteNonQuery();
            }
        }
        /// <summary>
        /// 返回SQLiteDataReader
        /// </summary>
        /// <param name="cmdText"></param>
        /// <param name="p"></param>
        /// <returns></returns>
        public static SQLiteDataReader ExecuteReader(string cmdText,params object[] p)
        {
            SQLiteConnection conn = GetSQLiteConnection();
            SQLiteCommand cmd = new SQLiteCommand();
            try
            {
                PrepareCommand(cmd,p);
                SQLiteDataReader reader = cmd.ExecuteReader(CommandBehavior.CloseConnection);
                return reader;
            }
            catch (Exception)
            {
                conn.Close();
                throw;
            }
        }
        /// <summary>
        /// 返回结果集的首行首列
        /// </summary>
        /// <param name="cmdText"></param>
        /// <param name="p"></param>
        /// <returns></returns>
        public static object ExecuteScalar(string cmdText,p);
                return cmd.ExecuteScalar();
            }
        }
        /// <summary>
        /// 分页获取DataSet
        /// </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 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,p);
                SQLiteDataAdapter da = new SQLiteDataAdapter(command);
                da.Fill(ds,(pageIndex - 1) * pageSize,pageSize,"result");
            }
            return ds;
        }
    }

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读