在.Net中操作SQLite数据库有什么优点

62次阅读
没有评论

共计 2924 个字符,预计需要花费 8 分钟才能阅读完成。

这篇文章将为大家详细讲解有关在.Net 中操作 SQLite 数据库有什么优点,丸趣 TV 小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

总结:

关于 SQLite 的库安装比较特殊:

下载地址:http://system.data.sqlite.org/index.html/doc/trunk/www/downloads.wiki  –ok!
              https://www.sqlite.org/download.html。— 用于安卓、Mac、Linux 等平台的下载。

下载安装包:
          sqlite-netFx20-setup-bundle-x64-2005-1.0.108.0.exe  — 测试 ok!
      或者 sqlite-netFx45-setup-bundle-x64-2012-1.0.108.0.exe   需要先卸载 2.0 版,再安装。— 测试 ok!
     (为了与其它软件保持一致,建议安装.Net 4.5 版本的!)

默认安装路径:C:\Program Files\System.Data.SQLite

.Net 引用:只需引用安装 bin 目录下的,System.Data.SQLite.dll 一个文件即可!

注意:

1、带 bundle 的表示动态库是按混合模式编译的,还有纯 x86 和纯 x64 模式的库,共 3 种,按实际需要选择。(与项目的生成 – 目标平台一致才行!)

2、下载的库,一定要安装,才行!!(只引用,未安装,运行会报错!!)

3、.Net 使用 SQLite,只需要引用 System.Data.SQLite.dll,根本用不着 sqlite3.dll。没想到吧!

SQLite 介绍:

SQLite,是一款轻型的数据库,用于本地的数据储存。开源数据库。

优点,它占用资源非常的低,在嵌入式设备中需要几百 K 的内存就够了;作为轻量级数据库,他的处理速度也足够快;支持的的容量级别为 T 级;独立: 没有额外依赖;开源;支持多种语言。

详细优点:

1、它的设计目标是嵌入式的,它占用资源非常的低,在嵌入式设备中,可能只需要几百 K 的内存就够了。

2、跨平台和多语言支持:它能够支持 Windows/Linux/Unix 等等主流的操作系统,同时能够跟很多程序语言相结合,
      比如 C, C++, PHP, Perl, Java, C#,Python, Ruby 等。

3、速度快:比起 Mysql、PostgreSQL 这两款开源的世界著名数据库管理系统来讲,它的处理速度比他们都快。
     (比一些流行的数据库在大部分普通数据库操作要快。)

4、支持数据库大小至 2TB。

5、足够小, 大致 13 万行 C 代码, 4.43M

6、简单, 轻松的 API

7、源码完全的开源, 你可以用于任何用途, 包括出售它。

8、它还支持事务处理功能等等。

使用.NET 操作 SQLLITE:

示例代码 1:

 public string Query() { string datasource =  e:/tmp/test.db  System.Data.SQLite.SQLiteConnection.CreateFile(datasource); // 连接数据库  System.Data.SQLite.SQLiteConnection conn = new System.Data.SQLite.SQLiteConnection(); System.Data.SQLite.SQLiteConnectionStringBuilder connstr = new System.Data.SQLite.SQLiteConnectionStringBuilder(); connstr.DataSource = datasource; connstr.Password =  admin // 设置密码,SQLite ADO.NET 实现了数据库密码保护  conn.ConnectionString = connstr.ToString(); conn.Open(); // 创建表  System.Data.SQLite.SQLiteCommand cmd = new System.Data.SQLite.SQLiteCommand(); string sql =  CREATE TABLE test(username varchar(20),password varchar(20))  cmd.CommandText = sql; cmd.Connection = conn; cmd.ExecuteNonQuery(); // 插入数据  sql =  INSERT INTO test VALUES( a , b)  cmd.CommandText = sql; cmd.ExecuteNonQuery(); // 取出数据  sql =  SELECT * FROM test  cmd.CommandText = sql; System.Data.SQLite.SQLiteDataReader reader = cmd.ExecuteReader(); StringBuilder sb = new StringBuilder(); while (reader.Read()) { sb.Append( username:).Append(reader.GetString(0)).Append(\n) .Append(password:).Append(reader.GetString(1)); } //MessageBox.Show(sb.ToString());
 return sb.ToString(); }

示例代码 2:事务操作:

using (SQLiteConnection conn = new SQLiteConnection(connectionString))
 { conn.Open();
 SQLiteCommand cmd = new SQLiteCommand();
 cmd.Connection = conn;
 SQLiteTransaction tx = conn.BeginTransaction();
 cmd.Transaction = tx;
 try
 { for (int n = 0; n   SQLStringList.Count; n++)
 { string strsql = SQLStringList[n].ToString();
 if (strsql.Trim().Length   1)
 {
 cmd.CommandText = strsql;
 cmd.ExecuteNonQuery();
 }
 }
 tx.Commit();
 }
 catch (System.Data.SQLite.SQLiteException E)
 { tx.Rollback();
 throw new Exception(E.Message);
 }

关于“在.Net 中操作 SQLite 数据库有什么优点”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-07-28发表,共计2924字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)