MongoDB samus驅動(2)

来源:http://www.cnblogs.com/9-9-9-9/archive/2017/05/18/6874762.html
-Advertisement-
Play Games

上一篇中提到驅動的鏈接方式,這篇給出完整鏈接代碼和使用實例 資料庫完整鏈接 添加數據: 更新數據: 更新,除了Update還有一個UpdateAll方法,不做過多解釋. 增,刪,改 沒什麼可說,主要說下查詢 簡單數據查詢: 靈活查詢: 可以看出只要給Find傳遞Document,然後接受數據就可以了 ...


上一篇中提到驅動的鏈接方式,這篇給出完整鏈接代碼和使用實例

資料庫完整鏈接

 1 static IMongo _mongo = null;
 2 public MongoDrive()//這個類集成了 IDisposable 介面
 3 {
 4     if (_mongo == null)
 5     {
 6         var connectionString = new MongoConnectionStringBuilder()
 7         {
 8             ConnectionTimeout = TimeSpan.FromSeconds(30),
 9             ConnectionLifetime = TimeSpan.FromSeconds(10),
10             MinimumPoolSize = 1,
11             MaximumPoolSize = 10,
12             Pooled = true,
13         };
14         connectionString.AddServer(new MongoServerEndPoint("127.0.0.1", 27017));
15         var config = new mongo.Configuration.MongoConfiguration();
16         config.ConnectionString = connectionString.ToString();
17         config.ReadLocalTime = false;
18         _mongo = new Mongo(config);
19         _mongo.Connect();
20     }
21 }
22 
23 public static IMongo Driver
24 {
25     get
26     {
27         return _mongo;
28     }
29 }

 

添加數據:

1 using (IDocumentDrive db = new MongoDB.MongoDrive())
2 {
3     db.Driver.Collection("docs").Insert(
4         new Document("uid",123456)
5         .Merge("uName","admin")
6         .Merge("age",new Document("去年八月",DateTime.Now))//Document 值為任何類型,
7         .Merge("addtime", DateTime.UtcNow)
8         );
9 }
Document 為samus驅動定義好的,實際是 IDictionary<string, object> 的封裝.

刪除數據:
1 using (IDocumentDrive db = new MongoDB.MongoDrive())
2     {
3         db.Driver.Collection("docs").Remove(new mongo.Document("uid", 123456));//刪除 UID = 123456 的文檔
4     }

更新數據:

1 using (IDocumentDrive db = new MongoDB.MongoDrive())
2 {
3     db.Driver.Collection("docs").Update(new mongo.Document("uName", "drop attr"), new mongo.Document("uid", 123456));
4 }

更新,除了Update還有一個UpdateAll方法,不做過多解釋.

 

增,刪,改 沒什麼可說,主要說下查詢

簡單數據查詢:

Document doc = db.Collection("docs").FindOne(new mongo.Document("uid",12346));//查詢出一個文檔,其數據保護文檔全部屬性及其子文檔,查找不到數據為 null,返回值為Document類型
使用時:
var age = doc["age"] //因為Document是Dictionary,所以可以直接使用中索引器取值
doc["uName"] = "mongdb samus";//賦值也是使用索引器
db.Collection("docs").Update(doc , new mongo.Document("uid", 123456));//之後更新這個文檔


db.Collection("docs").FindAll().Documents//FindAll 自然就是查詢全部文檔,FindAll()只返回了游標,調用FindAll().Documents才能正式獲取到值,
FindAll().Sort().Skip().Limit()//FindAll 還有幾個其他方法,Sort:排序 Skip:跳過條數 Limit:取值條數
Sort("age", MongoDB.IndexOrder.Descending)//排序
Skip(27)//跳過 27 條
Limit(28
)//取 28 條

FindAndModify:這個函數類似 UPDATE,
FindAndModify(新文檔結構,搜索條件,returnNew=true/false)//根據條件搜索文檔,找到則修改文檔為新文檔格式,並返迴文檔,返回的是新文檔,還是修改前的舊文檔,根據returnNew參數決定
還有其他參數如:upsert,是只更新第一個匹配項,還是更新全部匹配項

 

靈活查詢:

db.Collection("docs").Find(new Document("age", 27)).Documents;
Find:函數在項目里用的最多,主要是比較靈活.重載也比較多.
Find(new Document("age", 27), int limit, int skip)//分頁查詢
Find(new Document("age", 27))//條件查詢
FindAll 函數一樣,也是要調用 Documents 才能正常取值,否則只能取到游標.


Find(Document)//這種形式會返迴文檔全部結構,當查詢用戶時會返回用戶密碼,此時需要傳遞第二個參數
Find(new Document("age", 27),new Document("age", "").Merge("uid","空字元串即可"))//此時返回的文檔格式 只包含 age和uid 兩個屬性

可以看出只要給Find傳遞Document,然後接受數據就可以了.那麼複雜的肯定是如何構建Document,

下麵說下怎麼構建比較常用的查詢條件.

samus驅動有一個Op類.裡面定義了條件運算符函數,可以直接使用.

示例:

Op.GreaterThan(27)//生成的是mongoDB 的$gt //大於

Op.GreaterThanOrEqual(27)//生成的是mongoDB 的$gte //大於等於

Op.In(new string[]{"123465","123457","132458"})// IN 操作

根據名字可以直接看出具體是什麼意思,不全都寫註釋了.

Op里沒有現成Like函數,我擴展了下:

1         public static Document Like(string key)
2         {
3             return new Document().Merge(new Op().Add("$regex", key)).Merge(new Op().Add("$options", "$i"));
4         }

如何使用Op構建條件查詢:

//只做示例,條件肯定是永遠無法滿足的,勿糾結這個

new Document("uid","123456")    //uid=123456
.Merge("age",Op.GreaterThan(27))   // 並且 age > 27   
.Merge("addtime",Op.GreaterThan(DateTime.Now)) // 並且 addtime > 當前時間 說明:Op.GreaterThan可以比較不同類型,不一定非是 int
.Merge(
"age",new Document(Op.GreaterThan(15).Merge(Op.LessThanOrEqual(40)))) //並且 ( age>15 && age <40 )
.Merge("uid",new Document("$nin",new string[]{"123","124","124"})) //並且uid 不在 數組中 .
.Merge("uid",new Document("$in",new string[]{"666","777","888"})) //並且uid 在 666,777,888 中.
.Merge("face.big","http://www.salsnet.win/1.jpg")//搜索子文檔:文檔格式大概為{'uName':'abc',"face":{"small":"111.jpg","big":"222.jpg"}}

基本上構建查詢文檔就這些了,

 

分組查詢,聯合查詢,高級查詢下次再說


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 本文內容是本人參考多本經典C 書籍和一些前輩的博文做的總結 儘管.NET運行庫負責處理大部分記憶體管理工作,但C 程式員仍然必須理解記憶體管理的工作原理,瞭解如何高效地處理非托管的資源,才能在非常註重性能的系統中高效地處理記憶體。 C 編程的一個優點就是程式員不必擔心具體的記憶體管理,垃圾回收器會自動處理所 ...
  • redis 介紹和常用命令 redis簡介 Redis 是一款開源的,基於 BSD 許可的,高級鍵值 (key-value) 緩存 (cache) 和存儲 (store) 系統。由於 Redis 的鍵包括 string,hash,list,set,sorted set,bitmap 和 hyperl ...
  • 此貼為本人原創,轉載請註明出處 序 前幾天更新了被打入冷宮很久的酷狗,等進入之後就感覺菊花一緊————試 聽 居 然 都 要 開 通 音 樂 包(高品和無損)才行了,WTF! 這意味著以前緩存的都聽不了了,本著好馬不吃回頭草的原則,不打算去降級了,下載PJ版的又擔心被植入惡意代碼,心好累╮(╯▽╰) ...
  • 在部署IIS環境中,偶爾會遇到 404 錯誤,就算以前遇到過,也因為時間久了導致大概知道是什麼錯了,具體解決方案覺忘了,所以留下一個記錄,留給自己,也是給大家一點提醒。(註:錯誤信息也懶得截圖了,希望大家諒解) 1.百度看到好多人說在web.config文件中添加modules runAllMana ...
  • 背水一戰 Windows 10 之 控制項(集合類): Pivot, Hub ...
  • BarcodeLib -- 一個精簡而不失優雅的條形碼生成庫 引言 在百度進行“C# 條形碼”等類似關鍵字搜索的時候,基本上是使用 ZXing 類庫進行條形碼的生成。今天我所介紹的是另一款類庫 Barcode,一起來共同見證它的強大之處。 目錄 插曲 官方介紹 Nuget 安裝 支持的類型 簡單使用 ...
  • if( transform.position.x > -15 && transform.rotation.y == 0 ) { //小鳥X軸反方向移動速度 transform.position += new Vector3(-0.1f,0,0); } else { //小鳥Y軸旋轉,相當於人的轉身 ...
  • 在win10或者server2016上,我們安裝好IIS以後,把網站掛上去,訪問,可能會報下邊這個錯誤,這個時侯,其實我們應該首先意識到的是,錯誤並沒有告訴我們真正的原因,錯誤信息不全,所以,我們要做的不是立即找原因,而是把錯誤的詳細信息弄出來,如下: 500 - 內部伺服器錯誤。您查找的資源存在問 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...