Star 8K+,使用.NET开发的开源NoSQL数据库

发布时间:2024年01月13日

LiteDB 是一个轻量级、快速、易用的 .NET NoSQL 嵌入式数据库,完全用 C# 托管代码开发,并且是免费和开源的。它非常适合在移动应用(Xamarin iOS/Android)和小型的桌面/Web 应用中使用。

主要特点

  • 简单易用的 API,类似于 MongoDB
  • 100% C# 代码,支持 .NET 4.5 / NETStandard 1.3/2.0,其核心代码只有不到 450KB
  • 线程安全
  • 写入失败后的数据恢复(WAL 日志文件)
  • 使用 DES(AES)加密技术进行数据文件加密
  • 可使用属性或流畅的映射器 API 将 POCO 类映射到 BsonDocument
  • 支持存储文件和流式数据(类似于 MongoDB 中的 GridFS)
  • 单个数据文件存储(类似于 SQLite)
  • 支持索引文档字段以实现快速搜索
  • 支持 LINQ 查询
  • 提供类似 SQL 的命令来访问和转换数据
  • 开源免费,可用于商业用途
    LiteDB 还提供一个用于访问和管理数据的客户端LiteDBStudio,其功能简单强大,链接在文末。
    在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

使用方法

1、 安装LiteDB

可以通过 NuGet 包管理器安装 LiteDB

dotnet add package LiteDB --version 5.0.17
//或
NuGet\Install-Package LiteDB -Version 5.0.17

2、 创建数据库

using LiteDB;

var db = new LiteDatabase("mydb.db");

3、新建Person

public class Person
{
    public int Id { get; set; }
    public string Name { get; set; }
    public int Age { get; set; }
}

4、插入数据

var col = db.GetCollection<Person>("people");

var person = new Person
{
    Name = "John Doe",
    Age = 30
};

col.Insert(person);

5、查询数据

var results = col.Find(x => x.Age > 20);

foreach (var person in results)
{
    Console.WriteLine(person.Name);
}

6、更新数据

var person = col.FindById(1);

person.Name = "Jane Doe";

col.Update(person);

7、删除数据

col.Delete(1);

适用场景

LiteDB 非常适合以下场景:

  • 桌面/本地化的小应用程序
  • 应用程序文件格式(Application file format)
  • 小型 web 应用程序
  • 一个账户/用户一个数据库的数据存储
  • 少量并发写操作

官网推荐的一些第三方工具链接

  • 一个 GUI 查看器工具: https://github.com/falahati/LiteDBViewer
  • 一个 GUI 编辑器工具: https://github.com/JosefNemec/LiteDbExplorer
  • LiteDB 管理工具: https://darwich.mx/downloads/
  • Lucene.NET 目录: https://github.com/sheryever/LiteDBDirectory
  • LINQPad 支持: https://github.com/adospace/litedbpad
  • F# 支持: https://github.com/Zaid-Ajaj/LiteDB.FSharp
  • PowerShell 封装: https://github.com/v2kiran/PSLiteDB

源码链接:
LiteDB:https://github.com/mbdavid/LiteDB
LiteDBStudio:https://github.com/mbdavid/LiteDB.Studio

文章来源:https://blog.csdn.net/sd2208464/article/details/135566400
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。