一个小巧、快速、轻量级的 .NET NoSQL 嵌入式数据库

前言

今天给大家分享一个小巧、快速、轻量级的 .NET NoSQL 嵌入式数据库:LiteDB。本篇文章主要是介绍LiteDB和在.NET中如何使用。

LiteDB介绍

LiteDB 是一个小巧、快速和轻量级的 .NET NoSQL 嵌入式数据库。

  • 无服务器的 NoSQL 文档存储

  • 简单的 API,类似于 MongoDB

  • 100% 的 C# 代码支持 .NET 4.5 / NETStandard 1.3/2.0,以单个 DLL(不到 450KB)形式提供

  • 线程安全

  • 支持 ACID,完整的事务支持

  • 写入失败后的数据恢复(WAL 日志文件)

  • 使用 DES(AES)加密算法对数据文件进行加密

  • 使用属性或流畅的映射器 API 将 POCO 类映射为 BsonDocument

  • 存储文件和流数据(类似于 MongoDB 的 GridFS)

  • 单一数据文件存储(类似于 SQLite)

  • 对文档字段建立索引以实现快速搜索

  • 支持 LINQ 查询

  • 提供类似于 SQL 的命令来访问/转换数据

  • LiteDB Studio - 数据访问的精美用户界面

  • 开源且免费供所有人使用,包括商业用途

LiteDB应用场景

可以在以下场景中使用 LiteDB:

  • 桌面/本地小型应用程序

  • 应用程序文件格式

  • 小型网站/应用程序

  • 每个账户/用户数据存储一个数据库的情况

LiteDB项目源代码

创建一个LiteDBCwTest控制台

安装LiteDB包

搜索LiteDB包,点击安装。

定义Customer数据模型

复制代码
    public class Customer
    {
        /// <summary>
        /// Id
        /// </summary>
        public int Id { get; set; }

        /// <summary>
        /// Name
        /// </summary>
        public string Name { get; set; }

        /// <summary>
        /// Age
        /// </summary>
        public int Age { get; set; }

        /// <summary>
        /// Email
        /// </summary>
        public string Email { get; set; }
    }

LiteDB数据创建、插入、查询和删除

复制代码
namespace LiteDBCwTest
{
    internal class Program
    {
        static void Main(string[] args)
        {
            //创建或打开数据库文件
            using (var db = new LiteDatabase(@"MyCustomerData.db"))
            {
                // 获取集合(相当于表)
                var collection = db.GetCollection<Customer>("customers");

                var customers = new List<Customer>()
                {
                    new Customer
                    {
                        Name = "追逐时光者",
                        Age = 18,
                        Email = "17854545@gmail.com"
                    },
                    new Customer
                    {
                        Name = "大姚",
                        Age = 30,
                        Email = "16556545@gmail.com"
                    }
                };

                // 批量插入数据
                collection.Insert(customers);

                // 查询数据
                var result = collection.FindAll();

                foreach (var c in result)
                {
                    Console.WriteLine($"Name: {c.Name}, Age: {c.Age}, Email: {c.Email}");
                }

                // 根据条件查询数据
                var query = Query.EQ("Age", 30);
                var resultByAge = collection.Find(query);

                foreach (var c in resultByAge)
                {
                    Console.WriteLine($"Name: {c.Name}, Age: {c.Age}, Email: {c.Email}");
                }

                // 删除数据
                var deletedResult = collection.Delete(resultByAge.FirstOrDefault().Id);
            }
        }
    }
}

创建成功的数据库文件

LiteDB.Studio管理工具下载

用于查看和编辑 LiteDB v5 文档的图形用户界面工具。

LiteDB.Studio管理数据

连接MyCustomerData数据库

查看customers表数据

项目源码地址

更多项目实用功能和特性欢迎前往项目开源地址查看👀,别忘了给项目一个Star支持💖。

GitHub源码地址:GitHub - mbdavid/LiteDB: LiteDB - A .NET NoSQL Document Store in a single data file

官方文档地址:Overview - LiteDB :: A .NET embedded NoSQL database

文章转载自: 追逐时光者

原文链接: https://www.cnblogs.com/Can-daydayup/p/17955585

体验地址: 引迈 - JNPF快速开发平台_低代码开发平台_零代码开发平台_流程设计器_表单引擎_工作流引擎_软件架构

相关推荐
imuliuliang4 分钟前
MySQL的底层原理与架构
数据库·mysql·架构
尽兴-10 分钟前
Redis7 底层数据结构解析
数据结构·数据库·缓存·redis7
m0_7301151120 分钟前
自动化机器学习(AutoML)库TPOT使用指南
jvm·数据库·python
qq_4101942924 分钟前
SQL语句性能优化
数据库·sql·性能优化
小江的记录本1 小时前
【MyBatis-Plus】Spring Boot + MyBatis-Plus 进行各种数据库操作(附完整 CRUD 项目代码示例)
java·前端·数据库·spring boot·后端·sql·mybatis
wanhengidc1 小时前
《三国志异闻录》搬砖新游戏 云手机
运维·服务器·数据库·游戏·智能手机
2301_807367191 小时前
Python日志记录(Logging)最佳实践
jvm·数据库·python
2301_795741791 小时前
构建一个基于命令行的待办事项应用
jvm·数据库·python
FITA阿泽要努力1 小时前
《实战SQL: GROUP BY》
数据库·sql
sw1213892 小时前
Python字典与集合:高效数据管理的艺术
jvm·数据库·python