微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

SQLite Helper类,基于.net c#的SQLite数据库操作类

sqlite这个精巧的小数据库,无需安装软件,只需要一个System.Data.sqlite.DLL文件即可操作sqlite数据库。但是据说功能却非常强大。

简介:

SQLite一个开源数据库,现在已变得越来越流行,它的体积很小,被广泛应用于各种不同类型的应用中。sqlite已经是世界上布署得最广泛的sql数据库引擎,被用在无以计数的桌面电脑应用中,还有消费电子设备中,如移动电话、掌上电脑和MP3播放器等。sqlite的源码就放在公有领域(即WikiPedia的public domain)中。

开始使用:

Sqliteman,windows下最好的sqlite gui客户端 sqlite,sqliteman 7.72M 2008-8-30

sqliteman,windows...

SQLite Administrator 0.8.3.2┊是基于数据库引擎的管理工具┊汉化绿色特别版 sqlite 1.68M 2008-8-29

sqlite 是一个基于轻量级数据...

SQLite,除了access,mysql以外的另外一个轻量级数据库

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>

         获得连接对象

        </summary><returns></returns>

        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,255)">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];

            }

        }



        static DataSet ExecuteDataset(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;

        }



        static DaTarow ExecuteDaTarow(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];

            null;

        }



         返回受影响的行数

        <param name="cmdText">a</param><param name="commandParameters">传入的参数int ExecuteNonQuery(object[] p)

        {

            sqliteCommand command = new sqliteCommand();



            return command.ExecuteNonQuery();

            }

        }



         返回sqlDataReader对象

        <param name="cmdText"></param>static sqliteDataReader ExecuteReader(new sqliteCommand();

            sqliteConnection connection = GetsqliteConnection();

            try

            {

                PrepareCommand(command,p);

                sqliteDataReader reader = command.ExecuteReader(CommandBehavior.CloseConnection);

                return reader;

            }

            catch

            {

                connection.Close();

                throw;

            }

        }



         返回结果集中的第一行第一列,忽略其他行或列

        object ExecuteScalar(object[] p)

        {

            sqliteCommand cmd = using (sqliteConnection connection = GetsqliteConnection())

            {

                PrepareCommand(cmd,255)">return cmd.ExecuteScalar();

            }

        }



         分页

        <param name="recordCount"></param><param name="pageIndex"></param><param name="pageSize"></param><param name="countText"></param><param name="p"></param>static DataSet ExecutePager(ref int recordCount,255)">int pageIndex,255)">int pageSize,255)">string countText,255)">object[] p)

        {

            if (recordCount < 0)

                recordCount = int.Parse(ExecuteScalar(countText,p).ToString());



            DataSet ds = new DataSet();



            sqliteCommand command = new sqliteDataAdapter(command);

                da.Fill(ds,(pageIndex - 1) * pageSize,pageSize,result");

            }

            return ds;

        }

    }

}
以上是我根据SqlHelperOledbHelper修改而来。

原文地址:https://www.jb51.cc/sqlite/201692.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐