C# LiteDB基本使用示例代码
作者:qiandfeng
LiteDB是一种文档型单文件数据库,基于Key-Value方式存取数据,LiteDB 的灵感来自 MongoDB 数据库,所以它的 API 和 MongoDB 的 .NET API 非常相似,这篇文章主要介绍了C# LiteDB基本使用,需要的朋友可以参考下
LiteDB 是一个小型、快速、轻量级的 .NET NoSQL 嵌入式数据库,也就是我们常说的 K/V 数据库,完全用 C# 托管代码开发,并且是免费和开源的,Github Star 数近 7k。它非常适合在移动应用 (Xamarin iOS/Android)和小型的桌面/Web 应用中使用。
LiteDB 的灵感来自 MongoDB 数据库,所以它的 API 和 MongoDB 的 .NET API 非常相似。
LiteDB是一种文档型单文件数据库,基于Key-Value方式存取数据。
LiteDB的基本数据结构
BsonDocument
BsonDocument
用于存储单一对象,其构造函数接收字典型数据,定义存储的具体内容。
BsonArray
BsonArray
用于存储多项同类型对象,其构造函数接收对象集合。
BsonValue
BsonValue
是BsonDocument
和BsonArray
的公共基类,可以在运行时确定其具体类型,通过一系列As*
方法将其转换为具体类型。
LiteDB基本使用
1.创建实体类
创建一个实体类
{ public int Id { get; set; } public int Age { get; set; } public string Name { get; set; } = string.Empty; public string[] Phone { get; set; } public bool IsActive { get; set; } }
2.连接数据库以及一些CRUD
在NuGet中添加LiteDB
// 打开数据库,如果不存在就会自动创建 var db = new LiteDatabase(@"MyData.db"); // 增删改查案例 // 获取Student集合对象 var col = db.GetCollection<Student>("student"); for(int i = 1; i < 10; i++) { var student = new Student() { Id = i, Age = 18+i, Name = "Test", Phone = new string[] { "8000-1000"+i, "1001-8080"+i }, IsActive = true, }; // 数据插入 col.Insert(student); } // 在id字段上创建唯一索引 col.EnsureIndex(x => x.Id, true); // 数据查询 List<Student> list = col.Find(x => x.Age > 20).ToList(); Student user = col.FindOne(x => x.Id == 1); Console.WriteLine($"Lite数据库中共有{list.Count}人年龄大于20的人"); foreach (Student stu in list) { ShowInfo(stu); } Console.WriteLine("Lite数据库中Id为1的人"); ShowInfo(user); // 删除所有数据 col.DeleteAll(); } static void ShowInfo(Student student) { Console.WriteLine("姓名:"+student.Name + "年龄:"+student.Age); }
到此这篇关于C# LiteDB基本使用示例代码的文章就介绍到这了,更多相关C# LiteDB使用内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!