通用的CRUD之LiteDB

yizhihongxing

前言

你要开发一个系统,是不是首要任务是先建库,建表,建字段,既所谓的数据建模(听起来高大上一点,数据建模也确实是个烧脑的活),要费不少功夫。
不知你是否遇到过这样的场景。A产品有3个测试参数,B产品有6个测试参数,而且值和类型都各不相同,用SQL你要怎么建表呢?
有人会说这简单“参数名,参数值两列搞定”,NO!数据类型考虑了吗,数据量考虑了吗?
有人又说"每个参数建一列,A,B两个产品共建9列用来存各自的值。",如果某天C产品又有9个参数呢,又去增加字段?,你又说”item1,item2...N,多增加几十个备用",有考虑过查询吗?有考虑过他人看到这样的表不头大吗?
还有人说“一列JSON列搞定”,数据查询和数据统计一样把人折磨的不要不要的。

NOSQL的出现,让你眼前一亮,上面的问题迎刃而解。建库,建表,甚至建字段都是很愉悦的事情,你传入什么数据,NOSQL就给你自动创建好,相应的数据库和表(准确的说NoSQL的表叫数据集)。
同一个列可以有不同数据库类型,某一列存单纯的一个数字,还是一个对象都可以随心所欲。

今天要介绍的就是嵌入式NOSQL数据库,LiteDB,就是一个NOSQL版的SQLite。
LiteDB是嵌入式,跨平台,纯c#开发的轻量数据库。详情,请移步到https://www.litedb.org了解。
笔者使用LiteDB,掐指一算,已有6个年头,虽然踩过不少坑,经历过数据库损坏的痛苦经历,但依然没有放弃它,还是爱不释手,因为它在某些应用场景确实非常贴近我的需求。目前经历过几次版本迭代,功能也越来越完善。
现在切入正题
让我一步一步带你增删改查。

安装

Install-Package DbCRUD.LiteDB 安装包

插入数据

插入对象数据到DB

          var dic1 = new Dictionary<string, object>
          {
              { "_id", 2 },
              { "Name", "n2" },
              { "Qty", 200},
              //{ "DDate", DateTime.Now }
          };
          string dictable = "dicdata";
          var result= testdb.Upsert(dictable, dic1);

插入JSON数据到DB

  var dic1 = new Dictionary<string, object>
           {
               { "Name", "n2" },
               { "Qty", 19},
               //{ "DDate", DateTime.Now }
           };
           //异步插入
           string jsondata = JsonConvert.SerializeObject(dic1);
           var result = await testdb.InsertAsync("jsondata", jsondata); 

SQL命令插入,方便喜欢SQL语句的开发人员

testdb.Insert("insert Sqldata('name','date') value ('test','2023-04-16')");

批量插入

 //插入列表
           List<Dictionary<string, object>> listdata = new List<Dictionary<string, object>>();
           int maxid = testdb.Max<int>(dictable);
           for (int i = 0; i < 10; i++)
           {
               maxid++;
               var dic2 = new Dictionary<string, object>
               {
                   { "_id",maxid },
                   { "Name", "n2" },
                   { "Qty", 19},
                   { "DDate", DateTime.Now }
               };
               listdata.Add(dic2);
           }
           var listResult= testdb.Insert(dictable, listdata);

更新数据

            //更新部分字段数据
           var updata = new Dictionary<string, object>
           {
               { "Name", "updatetest" },
               { "Qty", 300}
           };
           var upresult = testdb.UpDate(dictable, updata, "_id=2");

更新及插入数据(数据存在更新,不存在插入)

          var dic1 = new Dictionary<string, object>
          {
              { "_id", 2 },
              { "Name", "n2" },
              { "Qty", 200},
              //{ "DDate", DateTime.Now }
          };
          string dictable = "dicdata";
          var result= testdb.Upsert(dictable, dic1);

查询数据

         testdb.Find<Dictionary<string, object>>(dictable, "_id=2")

删除数据

  string dictable = "dicdata";
  var result = testdb.Delete(dictable,2);

更多使用方法请移步到仓库 https://gitee.com/lzcode/db-crud


我的分享希望能给你带去帮助,您的打赏是我继续为您分享的动力。

通用的CRUD之LiteDB

原文链接:https://www.cnblogs.com/zzwen/archive/2023/05/05/17351036.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:通用的CRUD之LiteDB - Python技术站

(0)
上一篇 2023年5月6日
下一篇 2023年5月6日

相关文章

  • Python实现Event回调机制的方法

    下面是Python实现Event回调机制的方法的详细攻略。 一、什么是Event回调机制 Event回调机制是一种常用的编程模型,它将程序本身与用户的操作分离开来。通过事件触发机制,程序能够根据用户的操作来执行相应操作。比如,我们可以通过Event回调机制在GUI应用程序中实现对鼠标点击、键盘输入等事件的捕捉和响应。 二、Python实现Event回调机制的…

    C# 2023年6月7日
    00
  • Asp.net中判断一个session是否合法的方法

    在 ASP.NET 中,可以使用 Session 来存储用户访问网站时所需的信息,判断一个 Session 是否合法是非常重要的,可以防止未经授权的访问。下面是判断一个 Session 是否合法的方法的完整攻略: 判断 Session 是否存在 首先,我们需要判断 Session 是否存在。如果 Session 不存在,那么说明用户还没有登录或者 Sessi…

    C# 2023年6月3日
    00
  • C# 文字代码页 文字编码的代码页名称速查表

    C# 文字代码页指的是一种将文本编码成一系列数字(即字符编码)的方式,以便在像计算机中这样的设备上存储和处理文本数据。其中,文字编码的代码页名称速查表,简称编码表,是用于查找不同的编码方式和对应字符的表格。 C# 中常用的编码表有 ANSI、UTF-8、UTF-16 和 UTF-32。下面分别介绍它们的特点及示例说明。 ANSI 编码表 ANSI 编码表是美…

    C# 2023年5月31日
    00
  • C# DateTime.ToString根据不同语言生成相应的时间格式

    C#中的DateTime.ToString方法可以将日期时间格式化为指定的字符串。在不同的语言环境下,日期时间的格式也会有所不同。本文将介绍如何使用C#的DateTime.ToString方法根据不同语言生成相应的时间格式,并提供两个示例程序。 示例一:根据不同语言生成相应的时间格式 以下是一个C#程序的示例,它演示了如何根据不同语言生成相应的时间格式: u…

    C# 2023年5月15日
    00
  • C#预定义数据类型之值类型和引用类型介绍

    C#预定义数据类型之值类型和引用类型介绍 一、值类型和引用类型的区别 在C#中,数据类型可以分为值类型和引用类型两种。 值类型表示的是实际的值,它们被存储在堆栈中。当在一个方法中传递值类型之间的参数时,它们会被复制一份,因此赋予新值时不会影响原始的值。 值类型的数据包括: 布尔型(bool); 数字类型: 整型(byte、sbyte、short、ushort…

    C# 2023年5月31日
    00
  • WPF如何利用附加属性修改ShowGridLines效果详解

    下面是详细的攻略: 什么是WPF附加属性? WPF附加属性是一种特殊的属性,在WPF控件中可用。它允许你指定控件的属性,作用于其它控件,与父控件或者与容器进行交互。在XAML代码中,附加属性使用特殊的语法来定义:使用父控件名称作为前缀,并用一个“.”隔开,后面跟着属性名称。例如,Grid.Row=”1″中的“Row”是一个附加属性,作用于Grid实例,而非R…

    C# 2023年6月6日
    00
  • .NET Core利用动态代理实现AOP(面向切面编程)

    .NET Core 利用动态代理实现 AOP(面向切面编程) AOP(面向切面编程)是一种编程范式,它可以将横切关注点(如日志记录、性能统计、事务管理等)从业务逻辑中分离出来。在 .NET Core 中,可以使用动态代理来实现 AOP。本攻略将详细讲解 .NET Core 利用动态代理实现 AOP 的步骤。 1. 安装 NuGet 包 在 .NET Core…

    C# 2023年5月17日
    00
  • ASP.NET Core 3.x 并发限制的实现代码

    下面提供一份 ASP.NET Core 3.x 并发限制的实现代码完整攻略。 一、限制并发的原理 首先介绍一下限制并发的原理。在 ASP.NET Core 中,可以通过限制同时访问的线程数来限制并发。具体实现方式是使用 SemaphoreSlim 类,该类提供了限制线程访问的功能。 SemaphoreSlim 类具有两个重要的方法 WaitAsync 和 R…

    C# 2023年5月31日
    00
合作推广
合作推广
分享本页
返回顶部