小型数据库我一直使用SQLite。因为它是C语言开发,所以在C#中使用略显繁琐。LiteDB是类似于MongoDB的轻量级嵌入式数据库。因为它是完全使用C#开发,所以集成在C#应用程序中具有先天优势。和SQLite不同的是,LiteDB是NoSQL数据库,也就是K/V数据库,且完全开源、免费。除了可以在桌面应用程序中使用外,它可以在移动、WEB应用中使用。
LiteDB功能特性
从功能特性来看,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 = $"这是第{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的使用。它确实够轻量、够简单。是小型应用程序的一个不错的选择。