通用的CRUD之LiteDB

来源:https://www.cnblogs.com/zzwen/archive/2023/05/05/17351036.html
-Advertisement-
Play Games

前言 你要開發一個系統,是不是首要任務是先建庫,建表,建欄位,既所謂的數據建模(聽起來高大上一點,數據建模也確實是個燒腦的活),要費不少功夫。 不知你是否遇到過這樣的場景。A產品有3個測試參數,B產品有6個測試參數,而且值和類型都各不相同,用SQL你要怎麼建表呢? 有人會說這簡單“參數名,參數值兩列 ...


前言

你要開發一個系統,是不是首要任務是先建庫,建表,建欄位,既所謂的數據建模(聽起來高大上一點,數據建模也確實是個燒腦的活),要費不少功夫。
不知你是否遇到過這樣的場景。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


我的分享希望能給你帶去幫助,您的打賞是我繼續為您分享的動力。

做了就有可能!
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 新奧賽一本通,題1105 1105:數組逆序重存放 時間限制: 1000 ms 記憶體限制: 65536 KB 提交數: 70600 通過數: 47540 【題目描述】 將一個數組中的值按逆序重新存放。例如,原來的順序為8,6,5,4,1。要求改為1,4,5,6,8。 【輸入】 兩行:第一行數組中元素 ...
  • Java 的反射機制允許在程式運行期間,藉助反射 API 獲取類的內部信息,並能直接操作對象的內部屬性及方法。 ...
  • 基於java教師科研項目管理系統,可用於高校創新項目申報平臺,大學項目申報平臺,高校大創項目申報,大學生創新項目申報,高校科研管理平臺,科研管理平臺,技術類項目申報,互聯網+項目申報系統; ...
  • 此次記錄一次非常麻煩的調試問題,不是純知識分享,只是記錄這次調試過程引以為戒。 問題簡介 這個功能是公司2021年寫的老功能,一直都沒有更新過代碼,這次在導入一個1.03G的大文件進行讀取的過程中出問題了。 簡單介紹一下這個功能: 公司使用的spring boot框架構建項目,該功能為項目內的一個接 ...
  • 題目鏈接:LeetCode 59. 螺旋矩陣 II 本題不涉及演算法,只是簡單的模擬,但是由於邊界條件比較多,因此容易出錯。 分析題乾:題目要求按照右、下、左、上、這樣的順序對數組進行填充,填充的值為 1 ~ n*n,因此問題的關鍵就是找到待填充的位置,將其值賦值為 i 即可。 由於填充的順序是有規律 ...
  • 項目背景 根據旅游行業的這種現狀,提出解決問題的一個可行性方法,實現了旅游管理的網路化。 項目總體介紹 旅游系統設計分為前後網站和後臺管理系統,功能點包含旅游景點信息分類展示、景點詳情(地理位置、特色景點概述等)、下單預訂等功能; 角色分為管理員和普通用戶。 用戶可以對旅游線路及其詳細信息進行查詢、 ...
  • channel(一) ​ channel用於goroutines之間的通信,讓它們之間可以進行數據交換。像管道一樣,一個goroutine_A向channel_A中放數據,另一個goroutine_B從channel_A取數據 channel 基本語法 // 因為channel是指針類型的數據類型, ...
  • 作者:京東科技 南韓凱 一、問題發現與排查 1.1 找到問題原因 問題起因是我們收到了jdos的容器CPU告警,CPU使用率已經達到104% 觀察該機器日誌發現,此時有很多線程在執行跑批任務。正常來說,跑批任務是低CPU高記憶體型,所以此時考慮是FullGC引起的大量CPU占用(之前有類似情況,告知用 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...