Csharp/C#教程:C#操作SQLite数据库帮助类详解分享

本文实例讲述了C#操作SQLite数据库帮助类。分享给大家供大家参考,具体如下:

最近有WPF做客户端,需要离线操作存储数据,在项目中考虑使用Sqlite嵌入式数据库,在网上找了不少资料,最终整理出一个公共的帮助类。

Sqlite是一个非常小巧的数据库,基本上具备关系型数据库操作的大多数功能,Sql语法也大同小异。下面是我整理的帮助类代码:

1.获取SQLiteConnection对象,传入数据库有地址即可。

///<summary> ///获得连接对象 ///</summary> ///<returns>SQLiteConnection</returns> publicstaticSQLiteConnectionGetSQLiteConnection() { //Sqlite数据库地址 stringstr=AppDomain.CurrentDomain.BaseDirectory; varcon=newSQLiteConnection("DataSource="+str+"DataBass\InfoServiceDbB.db"); returncon; }

2.准备操作命令参数,构造SQLiteCommand对象:

///<summary> ///准备操作命令参数 ///</summary> ///<paramname="cmd">SQLiteCommand</param> ///<paramname="conn">SQLiteConnection</param> ///<paramname="cmdText">Sql命令文本</param> ///<paramname="data">参数数组</param> privatestaticvoidPrepareCommand(SQLiteCommandcmd,SQLiteConnectionconn,stringcmdText,Dictionary<String,String>data) { if(conn.State!=ConnectionState.Open) conn.Open(); cmd.Parameters.Clear(); cmd.Connection=conn; cmd.CommandText=cmdText; cmd.CommandType=CommandType.Text; cmd.CommandTimeout=30; if(data!=null&&data.Count>=1) { foreach(KeyValuePair<String,String>valindata) { cmd.Parameters.AddWithValue(val.Key,val.Value); } } }

3.查询,返回DataSet

///<summary> ///查询,返回DataSet ///</summary> ///<paramname="cmdText">Sql命令文本</param> ///<paramname="data">参数数组</param> ///<returns>DataSet</returns> publicstaticDataSetExecuteDataset(stringcmdText,Dictionary<string,string>data) { vards=newDataSet(); using(SQLiteConnectionconnection=GetSQLiteConnection()) { varcommand=newSQLiteCommand(); PrepareCommand(command,connection,cmdText,data); varda=newSQLiteDataAdapter(command); da.Fill(ds); } returnds; }

4.查询,返回DataTable

///<summary> ///查询,返回DataTable ///</summary> ///<paramname="cmdText">Sql命令文本</param> ///<paramname="data">参数数组</param> ///<returns>DataTable</returns> publicstaticDataTableExecuteDataTable(stringcmdText,Dictionary<string,string>data) { vardt=newDataTable(); using(SQLiteConnectionconnection=GetSQLiteConnection()) { varcommand=newSQLiteCommand(); PrepareCommand(command,connection,cmdText,data); SQLiteDataReaderreader=command.ExecuteReader(); dt.Load(reader); } returndt; }

5.返回一行数据DataRow

///<summary> ///返回一行数据 ///</summary> ///<paramname="cmdText">Sql命令文本</param> ///<paramname="data">参数数组</param> ///<returns>DataRow</returns> publicstaticDataRowExecuteDataRow(stringcmdText,Dictionary<string,string>data) { DataSetds=ExecuteDataset(cmdText,data); if(ds!=null&&ds.Tables.Count>0&&ds.Tables[0].Rows.Count>0) returnds.Tables[0].Rows[0]; returnnull; }

6.执行数据库操作

///<summary> ///执行数据库操作 ///</summary> ///<paramname="cmdText">Sql命令文本</param> ///<paramname="data">传入的参数</param> ///<returns>返回受影响的行数</returns> publicstaticintExecuteNonQuery(stringcmdText,Dictionary<string,string>data) { using(SQLiteConnectionconnection=GetSQLiteConnection()) { varcommand=newSQLiteCommand(); PrepareCommand(command,connection,cmdText,data); returncommand.ExecuteNonQuery(); } }

7.返回SqlDataReader对象

///<summary> ///返回SqlDataReader对象 ///</summary> ///<paramname="cmdText">Sql命令文本</param> ///<paramname="data">传入的参数</param> ///<returns>SQLiteDataReader</returns> publicstaticSQLiteDataReaderExecuteReader(stringcmdText,Dictionary<string,string>data) { varcommand=newSQLiteCommand(); SQLiteConnectionconnection=GetSQLiteConnection(); try { PrepareCommand(command,connection,cmdText,data); SQLiteDataReaderreader=command.ExecuteReader(CommandBehavior.CloseConnection); returnreader; } catch { connection.Close(); command.Dispose(); throw; } }

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

///<summary> ///返回结果集中的第一行第一列,忽略其他行或列 ///</summary> ///<paramname="cmdText">Sql命令文本</param> ///<paramname="data">传入的参数</param> ///<returns>object</returns> publicstaticobjectExecuteScalar(stringcmdText,Dictionary<string,string>data) { using(SQLiteConnectionconnection=GetSQLiteConnection()) { varcmd=newSQLiteCommand(); PrepareCommand(cmd,connection,cmdText,data); returncmd.ExecuteScalar(); } }

9.分页查询

///<summary> ///分页查询 ///</summary> ///<paramname="recordCount">总记录数</param> ///<paramname="pageIndex">页牵引</param> ///<paramname="pageSize">页大小</param> ///<paramname="cmdText">Sql命令文本</param> ///<paramname="countText">查询总记录数的Sql文本</param> ///<paramname="data">命令参数</param> ///<returns>DataSet</returns> publicstaticDataSetExecutePager(refintrecordCount,intpageIndex,intpageSize,stringcmdText,stringcountText,Dictionary<string,string>data) { if(recordCount<0) recordCount=int.Parse(ExecuteScalar(countText,data).ToString()); vards=newDataSet(); using(SQLiteConnectionconnection=GetSQLiteConnection()) { varcommand=newSQLiteCommand(); PrepareCommand(command,connection,cmdText,data); varda=newSQLiteDataAdapter(command); da.Fill(ds,(pageIndex-1)*pageSize,pageSize,"result"); } returnds; }

10.重新组织数据库

当你从SQLite数据库中删除数据时,未用的磁盘空间将会加入一个内部的“自由列表”中。

当你下次插入数据时,这部分空间可以重用。磁盘空间不会丢失,但也不会返还给操作系统。

如果删除了大量数据,而又想缩小数据库文件占用的空间,执行VACUUM命令。VACUUM将会从头重新组织数据库

你可以在你的程序中约定一个时间间隔执行一次重新组织数据库的操作,节约空间

publicvoidResetDataBass() { using(SQLiteConnectionconn=GetSQLiteConnection()) { varcmd=newSQLiteCommand(); if(conn.State!=ConnectionState.Open) conn.Open(); cmd.Parameters.Clear(); cmd.Connection=conn; cmd.CommandText="vacuum"; cmd.CommandType=CommandType.Text; cmd.CommandTimeout=30; cmd.ExecuteNonQuery(); } }

更多关于C#相关内容感兴趣的读者可查看本站专题:《C#常见数据库操作技巧汇总》、《C#常见控件用法教程》、《C#窗体操作技巧汇总》、《C#数据结构与算法教程》、《C#面向对象程序设计入门教程》及《C#程序设计之线程使用技巧上述就是C#学习教程:C#操作SQLite数据库帮助类详解分享的全部内容,如果对大家有所用处且需要了解更多关于C#学习教程,希望大家多多关注—计算机技术网(www.ctvol.com)!

本文来自网络收集,不代表计算机技术网立场,如涉及侵权请联系管理员删除。

ctvol管理联系方式QQ:251552304

本文章地址:https://www.ctvol.com/cdevelopment/907929.html

(0)
上一篇 2021年10月25日
下一篇 2021年10月25日

精彩推荐