SQLite介绍和使用
- public static class SqliteHelper
- {
- private static string connectionString = ConfigurationManager.ConnectionStrings["SqliteConnectionstring"].ConnectionString;
- /// <summary>
- /// 创建一个数据库文件。如果存在同名数据库文件,则会覆盖。
- /// </summary>
- /// <param name="dbName">数据库文件名。为null或空串时不创建。</param>
- /// <param name="password">(可选)数据库密码,默认为空。</param>
- /// <exception cref="Exception"></exception>
- public static void CreateDB(string dbName)
- {
- SQLiteConnection conn = null;
- string dbPath = "Data Source ="+ connectionString+"/"+dbName + ".db";
- conn = new SQLiteConnection(dbPath);//创建数据库实例,指定文件位置
- conn.Open();//打开数据库,若文件不存在会自动创建
- string sql = "CREATE TABLE IF NOT EXISTS T_BuildChildPath(Id integer IDENTITY(1,1), ProductsCode nvarchar(100), CodePath nvarchar(100), CreateTime datetime);";//建表语句
- SQLiteCommand cmdCreateTable = new SQLiteCommand(sql, conn);
- cmdCreateTable.ExecuteNonQuery();//如果表不存在,创建数据表
- conn.Close();
- }
- /// <summary>
- /// 对SQLite数据库执行增删改操作,返回受影响的行数。
- /// </summary>
- /// <param name="sql">要执行的增删改的SQL语句。</param>
- /// <param name="parameters">执行增删改语句所需要的参数,参数必须以它们在SQL语句中的顺序为准。</param>
- /// <returns></returns>
- /// <exception cref="Exception"></exception>
- public static int ExecuteNonQuery(string sql, params SQLiteParameter[] parameters)
- {
- int affectedRows = ;
- using (SQLiteConnection connection = new SQLiteConnection(connectionString))
- {
- using (SQLiteCommand command = new SQLiteCommand(connection))
- {
- try
- {
- connection.Open();
- command.CommandText = sql;
- if (parameters.Length != )
- {
- command.Parameters.AddRange(parameters);
- }
- affectedRows = command.ExecuteNonQuery();
- }
- catch (Exception ex) { throw; }
- }
- }
- return affectedRows;
- }
- public static int ExecuteNonQuery(string sql )
- {
- int affectedRows = ;
- using (SQLiteConnection connection = new SQLiteConnection(connectionString))
- {
- using (SQLiteCommand command = new SQLiteCommand(connection))
- {
- try
- {
- connection.Open();
- command.CommandText = sql;
- affectedRows = command.ExecuteNonQuery();
- }
- catch (Exception ex) { throw; }
- }
- }
- return affectedRows;
- }
- /// <summary>
- /// 批量处理数据操作语句。
- /// </summary>
- /// <param name="list">SQL语句集合。</param>
- /// <exception cref="Exception"></exception>
- public static void ExecuteNonQueryBatch(List<KeyValuePair<string, SQLiteParameter[]>> list)
- {
- using (SQLiteConnection conn = new SQLiteConnection(connectionString))
- {
- try { conn.Open(); }
- catch { throw; }
- using (SQLiteTransaction tran = conn.BeginTransaction())
- {
- using (SQLiteCommand cmd = new SQLiteCommand(conn))
- {
- try
- {
- foreach (var item in list)
- {
- cmd.CommandText = item.Key;
- if (item.Value != null)
- {
- cmd.Parameters.AddRange(item.Value);
- }
- cmd.ExecuteNonQuery();
- }
- tran.Commit();
- }
- catch (Exception) { tran.Rollback(); throw; }
- }
- }
- }
- }
- /// <summary>
- /// 执行查询语句,并返回第一个结果。
- /// </summary>
- /// <param name="sql">查询语句。</param>
- /// <returns>查询结果。</returns>
- /// <exception cref="Exception"></exception>
- public static object ExecuteScalar(string sql, params SQLiteParameter[] parameters)
- {
- using (SQLiteConnection conn = new SQLiteConnection(connectionString))
- {
- using (SQLiteCommand cmd = new SQLiteCommand(conn))
- {
- try
- {
- conn.Open();
- cmd.CommandText = sql;
- if (parameters.Length != )
- {
- cmd.Parameters.AddRange(parameters);
- }
- return cmd.ExecuteScalar();
- }
- catch (Exception) { throw; }
- }
- }
- }
- public static bool ExecuteScalar(string sql )
- {
- using (SQLiteConnection conn = new SQLiteConnection(connectionString))
- {
- using (SQLiteCommand cmd = new SQLiteCommand(conn))
- {
- try
- {
- conn.Open();
- cmd.CommandText = sql;
- return (Convert.ToInt32(cmd.ExecuteScalar()?.ToString()??"")>)?true:false;
- }
- catch (Exception) { throw; }
- }
- }
- }
- public static string ExecuteScalarStr(string sql)
- {
- using (SQLiteConnection conn = new SQLiteConnection(connectionString))
- {
- using (SQLiteCommand cmd = new SQLiteCommand(conn))
- {
- try
- {
- conn.Open();
- cmd.CommandText = sql;
- return cmd.ExecuteScalar()?.ToString();
- }
- catch (Exception) { throw; }
- }
- }
- }
- /// <summary>
- /// 执行一个查询语句,返回一个包含查询结果的DataTable。
- /// </summary>
- /// <param name="sql">要执行的查询语句。</param>
- /// <param name="parameters">执行SQL查询语句所需要的参数,参数必须以它们在SQL语句中的顺序为准。</param>
- /// <returns></returns>
- /// <exception cref="Exception"></exception>
- public static DataTable ExecuteQuery(string sql, params SQLiteParameter[] parameters)
- {
- using (SQLiteConnection connection = new SQLiteConnection(connectionString))
- {
- using (SQLiteCommand command = new SQLiteCommand(sql, connection))
- {
- if (parameters.Length != )
- {
- command.Parameters.AddRange(parameters);
- }
- SQLiteDataAdapter adapter = new SQLiteDataAdapter(command);
- DataTable data = new DataTable();
- try { adapter.Fill(data); }
- catch (Exception) { throw; }
- return data;
- }
- }
- }
- /// <summary>
- /// 执行一个查询语句,返回一个关联的SQLiteDataReader实例。
- /// </summary>
- /// <param name="sql">要执行的查询语句。</param>
- /// <param name="parameters">执行SQL查询语句所需要的参数,参数必须以它们在SQL语句中的顺序为准。</param>
- /// <returns></returns>
- /// <exception cref="Exception"></exception>
- public static SQLiteDataReader ExecuteReader(string sql, params SQLiteParameter[] parameters)
- {
- SQLiteConnection connection = new SQLiteConnection(connectionString);
- SQLiteCommand command = new SQLiteCommand(sql, connection);
- try
- {
- if (parameters.Length != )
- {
- command.Parameters.AddRange(parameters);
- }
- connection.Open();
- return command.ExecuteReader(CommandBehavior.CloseConnection);
- }
- catch (Exception) { throw; }
- }
- /// <summary>
- /// 查询数据库中的所有数据类型信息。
- /// </summary>
- /// <returns></returns>
- /// <exception cref="Exception"></exception>
- public static DataTable GetSchema()
- {
- using (SQLiteConnection connection = new SQLiteConnection(connectionString))
- {
- try
- {
- connection.Open();
- return connection.GetSchema("TABLES");
- }
- catch (Exception) { throw; }
- }
- }
- }
这里的SqliteConnectionstring连接字符串和SQL类似,Data Source改成对应的物理路径即可。
- <add name="SqliteConnectionstring" connectionString="Data Source=D:/ProductsIndex.db" providerName="System.Data.SqlClient" />
页面的调用:
- string sql = string.Format(@" select * from T_BuildChildPath where ProductsCode like '%" + PartCode + "%'");
- DataView dv = SqliteHelper.ExecuteQuery(sql).DefaultView;
SQLite介绍和使用的更多相关文章
- (转)Android学习笔记---SQLite介绍,以及使用Sqlite,进行数据库的创建,完成数据添删改查的理解
原文:http://blog.csdn.net/lidew521/article/details/8655229 1.SQLite介绍:最大特点是,无数据类型;除了可以使用文件或SharedPrefe ...
- SQLite介绍、学习笔记、性能测试
SQLite介绍.学习笔记.性能测试 哪些人,哪些公司或软件在用SQLite: Nokia's Symbian,Mozilla,Abobe,Google,阿里旺旺,飞信,Chrome,FireFox可 ...
- 【数据库】 SQLite 介绍
[数据库] SQLite 介绍 一. 特点 : 小而精悍 1. 轻量级 : 占用资源低 2. 嵌入式 : 无需安装,直接引用就可用 3. 支持 SQL 语法, 大部分兼容 Sql Server 语法, ...
- 学习笔记——SQLite介绍
简介:Google为android的较大数据的处理提供了SQLlite, 他在数据存储.管理.维护.等各方面都相当出色功能也非常强大. 1.创建数据库 Android 为了让我们能够更加方便地管理数据 ...
- Android中SQLite介绍
现在的主流移动设备像Android.iPhone等都使用SQLite作为复杂数据的存储引擎,在我们为移动设备开发应用程序时,也许就要使用到SQLite来存储我们大量的数据,所以我们就需要掌握移动设备上 ...
- SQLite介绍及使用
SQLite,是一款轻型的数据库,是遵守ACID的关联式数据库管理系统,它的设计目标是嵌入式的,而且目前已经在很多嵌入式产品中使用了它,它占用资源非常的低,在嵌入式设备中,可能只需要几百K的内存就够了 ...
- SQLite介绍
优点:轻量级.绿色组件.单一文件.跨平台.查询效率极高.使用事务插入速度极快.支持limit分页. 适合查询速度要求较高,内存占用较少的场合,尤其是嵌入式操作系统,如各种手机操作系统,低并发web(9 ...
- C#操作SQLite数据库
SQLite介绍 SQLite is a software library that implements a self-contained, serverless, zero-configurati ...
- 数据库SQLite
一.数据库 在项目开发中,通常都需要对数据进行离线缓存的处理,如新闻数据的离线缓存等.离线缓存一般都是把数据保存到项目的沙盒中.有以下几种方式: 归档:NSKeyedArchiver 偏好设置:NSU ...
随机推荐
- ServerManager.exe 0xc0000135 应用程序错误
问题: 将 Windows Server 2016 .NET Framework移除. IIS卸载后, Server Manager.exe.事件查看器等都无法正常开启. 解决方案: 在运行中,输入C ...
- linux下安装 ping 命令
使用docker仓库下载的ubuntu 14.04 镜像.里面精简的连 ping 命令都没有.google 百度都搜索不到ping 命令在哪个包里. 努力找了半天,在一篇文章的字里行间发现了 ping ...
- KAFKA && zookeeper 集群安装
服务器:#vim /etc/hosts10.16.166.90 sh-xxx-xxx-xxx-online-0110.16.168.220 sh-xx-xxx-xxx-online-0210.16.1 ...
- 【Python】[技术博客] 如何对使用PYQT编写的GUI文件进行单元测试
如何对使用PYQT编写的GUI文件进行单元测试 想要对PYQT编写的GUI文件进行单元测试,我们主要用到QTest QTest里面包含了一些对窗体的各种控件进行模拟操作的函数,通过QTest对窗体进行 ...
- sql server查看表大小
查看SqlServer 数据库中各个表多少行 : SELECT A.NAME ,B.ROWS FROM sysobjects A JOIN sysindexes B ON A.id = B.id WH ...
- 在线生成安卓APP图标
移动应用图标/启动图生成工具,一键生成所有尺寸的应用图标/启动图 在线生成安卓APP图标生成 图标在 线 在线图标 安卓图标 生成图标 https://icon.wuruihong.com/ 在线pn ...
- 解决ffmpeg拉流转发频繁丢包问题max delay reached. need to consume packet
软件: 1.流媒体服务器EasyDarwin-windows-8.1.0-1901141151 2.ffmpeg-20181001-dcbd89e-win64-static 3.直播源:rtsp:// ...
- 【Python】解析Python中的文件操作
目录结构: contents structure [-] 简介 Python中的文件类型 内置函数的文件操作 open()函数 Mode 创建文本文件 读取文本文件 循环文件对象 关闭文件 With语 ...
- Java12新特性 -- 其他新增,移除,废弃项
支持unicode 11 JDK 12版本包括对Unicode 11.0.0的支持.在发布支持Unicode 10.0.0的JDK 11之后,Unicode 11.0.0引 入了以下JDK 12中包含 ...
- WMS 162服务器空间满,清日志
/usr/local/tomcat-ibus/logs/usr/local/tomcat-ibus/bin/logs/usr/local/tomcat-api/bin/logs/usr/local/t ...