轻量级LiteDB数据库的C#实现

发表时间: 2023-07-31 09:09

LiteDB简介

小型数据库我一直使用SQLite。因为它是C语言开发,所以在C#中使用略显繁琐。LiteDB是类似于MongoDB的轻量级嵌入式数据库。因为它是完全使用C#开发,所以集成在C#应用程序中具有先天优势。和SQLite不同的是,LiteDB是NoSQL数据库,也就是K/V数据库,且完全开源、免费。除了可以在桌面应用程序中使用外,它可以在移动、WEB应用中使用。

LiteDB功能特性

  1. 无服务器 NoSQL 文档存储;
  2. 类似于 MongoDB 的简洁 API;
  3. 支持 .NET 4.5 / NETStandard 2.0;
  4. 线程安全;
  5. LINQ 查询的支持;
  6. 具有完整事务支持的 ACID;
  7. 单文件存储,类似于 SQLite;
  8. 存储文件和流数据;
  9. LiteDB Studio - 数据查询工具;
  10. 开源免费

从功能特性来看,LiteDB还是很强的,尤其难得的是支持并发,这点连SQLite也不具备。但是LiteDB历史较短,其稳定性和可靠性还需要进一步提升。下图是我从网上找的LiteDB和SQLite性能测试对比。此图中的数据我本人没有实际验证过,仅供大家参考

图1 LiteDB和SQLite性能对比

使用入门

首先通过NuGet安装最新的稳定版LiteDB。

图2 安装LiteDB

然后新建一个实体类。网上的文章连范例都懒的做,千篇一律照抄官方的Customer类。我们当然不能这么干。这里我创建了一个上位机开发中用于记录操作事件的EventModel类。

internal class EventModel{    public int Id { get; set; }    public DateTime DT { get; set; }          //日期时间    public string Operator { get; set; }      //操作员    public string Event { get; set; }         //事件描述    public string Remarks { get; set; }       //备注    public DateTime Timestamp { get; set; }   //时间戳}

在窗体上添加三个按钮,分别用于插入、修改和删除数据。在插入按钮的点击事件中输入下面代码。

//打开数据库,没有的话自动创建using (var db = new LiteDatabase(@"Data.db")){    //获取记录集,没有的话会自动创建    var lst = db.GetCollection<EventModel>("EventModel");    //模拟数据    List<EventModel> eventModels = new List<EventModel>();    for (int i = 0; i < 10; i++)    {        EventModel em = new EventModel();        em.DT = DateTime.Now;        em.Operator = "HwLib";        em.Event = $"这是第{i + 1}次操作";        em.Remarks = string.Empty;        em.Timestamp = DateTime.Now;        eventModels.Add(em);    }    //插入记录    lst.Insert(eventModels);}

上面的代码模拟了一次性插入10次操作的记录数据。我们可以通过DataGridView控件可以查看数据库中的数据。

图3 插入10个操作记录

另外LiteDB还提供了一个名为LiteDB Studio的可视化工具。我们也可以借助它查询、操作数据。

图4 LiteDB Studio

双击修改按钮,在其点击事件中输入下面代码。

using (var db = new LiteDatabase(@"Data.db")){     var lst = db.GetCollection<EventModel>("EventModel");     EventModel em = lst.FindOne(x => x.Event == "这是第4次操作");     em.Event = "这是第14次操作";     lst.Update(em);                }

上面的代码先查找操作事件是"这是第4次操作"的记录,然后再将其修改为"这是第14次操作"。数据的删除也很简单。双击删除按钮,在其点击事件中输入下面代码。

using (var db = new LiteDatabase(@"Data.db")){    ILiteCollection<EventModel> lst = db.GetCollection<EventModel>("EventModel");    EventModel em = lst.FindOne(x => x.Event == "这是第3次操作");    lst.Delete(em.Id);}

上面的代码删除了事件内容为"这是第3次操作"的记录。执行后的数据如下。

图5 删除记录

通过简单的增、删、查、改我们得以初步了解LiteDB的使用。它确实够轻量、够简单。是小型应用程序的一个不错的选择。