c# LiteDB的基础用法

打印 上一主题 下一主题

主题 908|帖子 908|积分 2724

LiteDB 是一个轻量级的嵌入式 NoSQL 数据库,其计划理念与 MongoDB 雷同,但它是完全使用 C# 开发的,因此与 C# 应用程序的集成非常顺畅。与 SQLite 相比,LiteDB 提供了 NoSQL(即键值对)的数据存储方式,并且是一个开源且免费的项目。它适用于桌面、移动以及 Web 应用程序。
安装 LiteDB 包

你可以通过 NuGet 包管理器来安装 LiteDB:
  1. Install-Package LiteDB
复制代码
定义数据模子

定义一个 FileModel 类来表示文件信息:
  1. using LiteDB;  
  2.   
  3. namespace YourNamespace  
  4. {  
  5.     [BsonCollection("files")] // 可以指定集合名称  
  6.     public class FileModel  
  7.     {  
  8.         [BsonId] // 标记为主键  
  9.         public int Id { get; set; }  
  10.         
  11.         public string Path { get; set; }  
  12.     }  
  13. }
复制代码
数据访问服务类

创建一个 FileServices 类来封装对 LiteDB 的数据操纵:
  1. using LiteDB;
  2. namespace UploadLogiData.LiteSql
  3. {
  4.     /// <summary>
  5.     /// Logitech数据操作类
  6.     /// </summary>
  7.     public class FileServices
  8.     {
  9.         /// <summary>
  10.         /// 定义数据库名称,文件在当前程序目录
  11.         /// </summary>
  12.         readonly string database = @"LogiDB.db";
  13.         /// <summary>
  14.         /// 打开一个表
  15.         /// </summary>
  16.         /// <returns></returns>
  17.         public ILiteCollection<FileModel> GetCollection(LiteDatabase db)
  18.         {
  19.             return db.GetCollection<FileModel>("Files");
  20.         }
  21.         /// <summary>
  22.         /// 插入数据(初始化)
  23.         /// </summary>
  24.         public void Initialize()
  25.         {
  26.             // 打开数据库 (如果不存在则创建)
  27.             using (var db = new LiteDatabase(database))
  28.             {
  29.                 var cg = GetCollection(db);
  30.                 cg.Delete(1);
  31.                 FileModel file = new FileModel
  32.                 {
  33.                     Id = 1,
  34.                     Path = @"C:\Users\ch190006\Desktop\Loginet\logs",
  35.                 };
  36.                 cg.Insert(file);
  37.             }
  38.         }
  39.         /// <summary>
  40.         /// 根据主键查询出配置单条数据
  41.         /// </summary>
  42.         /// <returns></returns>
  43.         public FileModel GetSingle(int id)
  44.         {
  45.             using (var db = new LiteDatabase(database))
  46.             {
  47.                 var cg = GetCollection(db);
  48.                 return cg.FindOne(p1 => p1.Id == id);
  49.             }
  50.         }
  51.         /// <summary>
  52.         /// 更新
  53.         /// </summary>
  54.         /// <param name="value">更新字段</param>
  55.         public void UpdatePath(string value)
  56.         {
  57.             using (var db = new LiteDatabase(database))
  58.             {
  59.                 var cg = GetCollection(db);
  60.                 // //查询到数据
  61.                 var data = cg.FindOne(p1 => p1.Id == 1);
  62.                 data.Path = value;
  63.                 // 当中数据库中查找到数据后,比如上面的data,可以直接修改后再更新。
  64.                 cg.Update(data);
  65.             }
  66.         }
  67.     }
  68. }
复制代码
使用示例
  1. using System;  
  2.   
  3. namespace YourNamespace  
  4. {  
  5.     class Program  
  6.     {  
  7.         static void Main(string[] args)  
  8.         {  
  9.              FileServices file = new FileServices();
  10.              file.Initialize();
  11.              file.UpdatePath(textLog.Text);
  12.              file.GetSingle(1).Path;
  13.         }  
  14.     }  
  15. }
复制代码
使用场景


  • 桌面应用程序:LiteDB 非常适合用于桌面应用程序,由于它是一个嵌入式数据库,可以轻松与应用程序一起打包和分发。它不必要单独的数据库服务器,简化了摆设和配置
  • 移动应用程序:由于 LiteDB 的轻量级和嵌入式特性,它也适用于移动应用程序。开发者可以在移动设备上存储和检索数据,而无需依赖远程服务器。
  • 小型 Web 应用程序:对于必要轻量级数据存储解决方案的小型 Web 应用程序,LiteDB 是一个不错的选择。它易于设置和使用,且性能精良。
  • 原型计划和测试:在开发早期阶段或进行原型计划时,使用 LiteDB 可以快速搭建数据存储和检索功能,而无需投入大量时间设置和维护复杂的数据库系统。
  • 一个账户/用户一个数据库的数据存储
  • 本地缓存:在某些环境下,开发者可能希望将数据缓存在本地以进步性能或减少网络延迟。LiteDB 可以作为这种本地缓存的解决方案。

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

自由的羽毛

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表