C# SQLite 帮助类分享

2 篇文章 0 订阅

1、在5月份的使用做一个小型管理软件,用到Sqlite, 最近几天又用到,因此整一个C# 上,Sqlite的帮助类 

 如下:

 

 /// <summary>
    /// SQLITE 帮助类
    /// </summary>
    class SQLiteHelper
    {
        private static SQLiteHelper mInstance = null;

        private String mConnectdbPath = "Data Source=" + Environment.CurrentDirectory + "\\active.db";

        private static Object mLockObject = new Object();

        /// <summary>
        /// 构造函数
        /// </summary>
        private SQLiteHelper()
        {
        }

        /// <summary>
        /// 初始化实例
        /// </summary>
        /// <returns></returns>
        public static SQLiteHelper GetInstance()
        {
            if (mInstance == null)
            {
                lock (mLockObject)
                {
                    mInstance = new SQLiteHelper();
                }
            }

            return mInstance;
        }


        /// <summary>  
        /// 对SQLite数据库执行增删改操作,返回受影响的行数。  
        /// </summary>  
        /// <param name="sql">要执行的增删改的SQL语句</param>  
        /// <param name="parameters">执行增删改语句所需要的参数,参数必须以它们在SQL语句中的顺序为准</param>  
        /// <returns></returns>  
        public int ExecuteNonQuery(String sql, SQLiteParameter[] paramters)
        {
            int affectedRows = 0;

            try
            {
                using (SQLiteConnection conn = new SQLiteConnection(mConnectdbPath))
                {
                    conn.Open();
                    using (DbTransaction transaction = conn.BeginTransaction())
                    {
                        using (SQLiteCommand cmd = new SQLiteCommand(sql, conn))
                        {
                            cmd.CommandText = sql;
                            if (paramters != null)
                            {
                                cmd.Parameters.AddRange(paramters);
                            }

                            affectedRows = cmd.ExecuteNonQuery();
                        }

                        transaction.Commit();
                    }
                }
            }
            catch (Exception e)
            {
                throw new Exception(e.Message);
            }

            return affectedRows;
        }

        /// <summary>  
        /// 对SQLite数据库执行增删改操作,返回受影响的行数。  
        /// </summary>  
        /// <param name="sql">要执行的增删改的SQL语句</param>  
        /// <returns></returns>  
        public int ExecuteNonQuery(String sql)
        {
            int affectedRows = 0;

            try
            {
                using (SQLiteConnection conn = new SQLiteConnection(mConnectdbPath))
                {
                    conn.Open();
                    using (DbTransaction transaction = conn.BeginTransaction())
                    {
                        using (SQLiteCommand cmd = new SQLiteCommand(conn))
                        {
                            cmd.CommandText = sql;
                            affectedRows = cmd.ExecuteNonQuery();
                        }

                        transaction.Commit();
                    }
                }
            }
            catch (Exception e)
            {
                throw new Exception(e.Message);
            }

            return affectedRows;
        }

        /// <summary>  
        /// 执行一个查询语句,返回一个包含查询结果的DataTable  
        /// </summary>  
        /// <param name="sql">要执行的查询语句</param>  
        /// <returns></returns>  
        public DataTable ExecuteQueryDataTable(String sql)
        {
            DataTable data = null;

            try
            {
                using (SQLiteConnection conn = new SQLiteConnection(mConnectdbPath))
                {
                    conn.Open();
                    using (DbTransaction transaction = conn.BeginTransaction())
                    {
                        using (SQLiteCommand cmd = new SQLiteCommand(sql, conn))
                        {
                            SQLiteDataAdapter adapter = new SQLiteDataAdapter(cmd);
                            data = new DataTable();

                            adapter.Fill(data);
                        }

                        transaction.Commit();
                    }
                }
            }
            catch (Exception e)
            {
                throw new Exception(e.Message);
            }

            return data;
        }
        /*
        public List<RecordJaveBean> ExecuteQuery(String sql)
        {
            try
            {
                mList.Clear();
                using (SQLiteConnection conn = new SQLiteConnection(mConnectdbPath))
                {
                    conn.Open();
                    SQLiteCommand cmdRead = new SQLiteCommand(sql, conn);

                    using (SQLiteDataReader reader = cmdRead.ExecuteReader())
                    {
                        while (reader.Read())
                        {
                            mList.Add(new RecordJaveBean(reader.GetString(1), reader.GetString(2), reader.GetString(3)));
                        }
                    }
                }
            }
            catch (Exception e)
            {
                throw new Exception(e.Message);
            }

            return mList;
        }
        */
        public void ExecuteInsert(String sql)
        {
            try
            {
                using (SQLiteConnection conn = new SQLiteConnection(mConnectdbPath))
                {
                    conn.Open();

                    SQLiteCommand cmdRead = new SQLiteCommand(sql, conn);
                    cmdRead.ExecuteReader();
                }
            }
            catch (Exception e)
            {
                throw new Exception(e.Message);
            }
        }

        public void ExecuteDelegate(String sql)
        {
            try
            {
                using (SQLiteConnection conn = new SQLiteConnection(mConnectdbPath))
                {
                    conn.Open();

                    SQLiteCommand cmdRead = new SQLiteCommand(sql, conn);
                    cmdRead.ExecuteReader();
                }
            }
            catch (Exception e)
            {
                throw new Exception(e.Message);
            }
        }


        /// <summary>  
        /// 对SQLite数据库获取当家查询结果集的记录总数
        /// </summary>  
        /// <param name="sql">要执行的增删改的SQL语句</param>  
        /// <returns></returns>  
        public int ExecuteGetResultTotalLine(String sql)
        {
            int lines = 0;

            try
            {
                using (SQLiteConnection conn = new SQLiteConnection(mConnectdbPath))
                {
                    conn.Open();
                    using (DbTransaction transaction = conn.BeginTransaction())
                    {
                        using (SQLiteCommand cmd = new SQLiteCommand(conn))
                        {
                            cmd.CommandText = sql;
                            lines = Convert.ToInt32(cmd.ExecuteScalar());
                        }

                        transaction.Commit();
                    }
                }
            }
            catch (Exception e)
            {
                throw new Exception(e.Message);
            }

            return lines;
        }

    }

 

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值