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
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...