C#使用SQLite(含加密)保姆级教程

C#使用SQLite

涉及框架及库

自己在NuGet管理器里面安装即可

  • Chloe.SQLite:ORM框架
  • Microsoft.Data.Sqlite.Core:驱动
  • SQLitePCLRaw.bundle_e_sqlcipher:SQLite加密扩展

复制runtimes

主要复制两个dll:e_sqlite3.dlle_sqlcipher.dll
复制到项目根目录下,保持原有的结构,删除不使用的平台即可,设置属性为如果较新则复制
在这里插入图片描述

dll文件查找位置主要是自己的nuget缓存目录中
在这里插入图片描述

或者自己去NuGet下载:SQLitePCLRaw.lib.e_sqlite3SQLitePCLRaw.lib.e_sqlcipher
在这里插入图片描述

然后用压缩软件打开即可获取到dll文件
在这里插入图片描述

创建加密SQLite文件

生成连接字串

使用SqliteConnectionStringBuilder类,我们可以便捷的构建数据库连接字符串。

SqliteConnectionStringBuilder sqliteConnectionStringBuilder = new SqliteConnectionStringBuilder();
sqliteConnectionStringBuilder.DataSource = "tanovo.db";
sqliteConnectionStringBuilder.Password = "123456";
sqliteConnectionStringBuilder.Mode = SqliteOpenMode.ReadWriteCreate;
SQLiteConnectionString = sqliteConnectionStringBuilder.ToString();

后续想在项目任何地方使用数据库,只需要使用

using var db = App.sqlite;

获取数据库上下文对象即可。

执行SQL生成表

如果不至少生成一个表在库中的话,则生成的数据库文件是非加密的,可能只有数据库有数据时,数据库才是加密类型的。

using var db = App.sqlite;
db.Session.ExecuteNonQuery(@"
    CREATE TABLE IF NOT EXISTS test_table
    (
      id INTEGER PRIMARY KEY AUTOINCREMENT,
      name TEXT,
      update_time TEXT,
      cteate_time TEXT
    );");

SQLiteConnectionFactory.cs

提供一下这个工厂类,方便伸手党直接复制了

using Chloe.Infrastructure;
using Microsoft.Data.Sqlite;
using System.Data;

namespace TestSqliteC.DatabaseHelper
{
    public class SQLiteConnectionFactory : IDbConnectionFactory
    {
        string _connString = null;

        public SQLiteConnectionFactory(string connString)
        {
            this._connString = connString;
        }

        public IDbConnection CreateConnection()
        {
            IDbConnection conn = new SqliteConnection(this._connString);
            return conn;
        }
    }
}

代码结构

因为我是WPF程序,所以在App构造函数中对SQLite就进行初始化操作了。
在这里插入图片描述

最后

这里还推荐三个开源项目,一个是嵌入式的NoSQL数据库,一个是文件存储引擎,都是同一个人开发的,项目也很不错!
最后一个是SQLiteStudio,可以打开并浏览SQLite加密数据库文件,提供图形化界面,可以管理数据库文件。

  1. LiteDB
  2. FileDB
  3. SQLiteStudio

相关推荐

  1. conda保姆使用教程

    2024-03-30 11:48:02       66 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-03-30 11:48:02       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-03-30 11:48:02       100 阅读
  3. 在Django里面运行非项目文件

    2024-03-30 11:48:02       82 阅读
  4. Python语言-面向对象

    2024-03-30 11:48:02       91 阅读

热门阅读

  1. RISC-V单板计算机模拟和FPGA板多核IP实现

    2024-03-30 11:48:02       42 阅读
  2. axios详解

    2024-03-30 11:48:02       31 阅读
  3. 在银河麒麟系统中安装nginx

    2024-03-30 11:48:02       146 阅读
  4. Python数据结构与算法——数据结构(栈、队列)

    2024-03-30 11:48:02       42 阅读
  5. C#WPF控件Button详解

    2024-03-30 11:48:02       38 阅读
  6. C#热门技术应用:探索.NET Core与ASP.NET Core的前沿

    2024-03-30 11:48:02       43 阅读
  7. Conda 命令

    2024-03-30 11:48:02       47 阅读
  8. 3月28日,每日信息差

    2024-03-30 11:48:02       35 阅读
  9. TCL常用语法

    2024-03-30 11:48:02       42 阅读