C#开发的轻量级LiteDB数据库

C#开发的轻量级LiteDB数据库

编码文章call10242025-04-25 11:09:1711A+A-

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性能测试对比。此图中的数据我本人没有实际验证过,仅供大家参考

使用入门

首先通过NuGet安装最新的稳定版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 = #34;这是第{i + 1}次操作";
        em.Remarks = string.Empty;
        em.Timestamp = DateTime.Now;
        eventModels.Add(em);
    }


    //插入记录
    lst.Insert(eventModels);
}

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

另外LiteDB还提供了一个名为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次操作"的记录。执行后的数据如下。

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

点击这里复制本文地址 以上内容由文彬编程网整理呈现,请务必在转载分享时注明本文地址!如对内容有疑问,请联系我们,谢谢!
qrcode

文彬编程网 © All Rights Reserved.  蜀ICP备2024111239号-4