C#簡(jiǎn)單操作MongoDB的步驟全紀(jì)錄
前言
MongoDB是一款由C++編寫的高性能、開源、無(wú)模式的常用非關(guān)系型數(shù)據(jù)庫(kù)產(chǎn)品,是非關(guān)系數(shù)據(jù)庫(kù)當(dāng)中功能最豐富、最像關(guān)系數(shù)據(jù)庫(kù)的數(shù)據(jù)庫(kù)。它擴(kuò)展了關(guān)系型數(shù)據(jù)庫(kù)的眾多功能,例如:輔助索引、范圍查詢、排序等。
MongoDB主要解決的是海量數(shù)據(jù)的訪問(wèn)效率問(wèn)題,它作為分布式數(shù)據(jù)崛起后,使用較多的一款非結(jié)構(gòu)數(shù)據(jù)庫(kù),必然有其值得稱道之處,它的主要功能特性如下:
1)面向集合的存儲(chǔ),適合存儲(chǔ)對(duì)象及JSON形式的數(shù)據(jù)。
2)動(dòng)態(tài)查詢,MongoDB支持豐富的查詢表達(dá)式。查詢指令使用JSON形式的標(biāo)記,可輕易查詢文檔中內(nèi)嵌的對(duì)象及數(shù)組。
3)完整的索引支持,包括文檔內(nèi)嵌對(duì)象及數(shù)組。MongoDB的查詢優(yōu)化器會(huì)分析查詢表達(dá)式,并生成一個(gè)高效的查詢計(jì)劃。
4)查詢監(jiān)視,MongoDB包含一個(gè)監(jiān)視工具用于分析數(shù)據(jù)庫(kù)操作的性能。
5)復(fù)制及自動(dòng)故障轉(zhuǎn)移,MongoDB數(shù)據(jù)庫(kù)支持服務(wù)器之間的數(shù)據(jù)復(fù)制,支持主-從模式及服務(wù)器之間的相互復(fù)制。復(fù)制的主要目標(biāo)是提供冗余及自動(dòng)故障轉(zhuǎn)移。
6)高效的傳統(tǒng)存儲(chǔ)方式,支持二進(jìn)制數(shù)據(jù)及大型對(duì)象(如圖片或視頻)。
7)自動(dòng)分片以支持云級(jí)別的伸縮性,自動(dòng)分片功能支持水平的數(shù)據(jù)庫(kù)集群,可動(dòng)態(tài)添加額外的機(jī)器。
本文主要給大家介紹了關(guān)于C#操作MongoDB的相關(guān)內(nèi)容,分享出來(lái)供大家參考學(xué)習(xí),下面話不多說(shuō)了,來(lái)一起看看詳細(xì)的介紹吧
一 安裝MongoDB
官網(wǎng)按需下載, 安裝, 一步到位.
二 VS創(chuàng)建新項(xiàng)目
創(chuàng)建一個(gè).netcore console項(xiàng)目, 然后nuget安裝驅(qū)動(dòng)MongoDB.Driver
三 建立連接
在Program.Main
函數(shù)中添加代碼
var client = new MongoClient("mongodb://127.0.0.1:27017"); var database = client.GetDatabase("foo"); var collection = database.GetCollection<BsonDocument>("bar");
三個(gè)對(duì)象, client是連接數(shù)據(jù)庫(kù)的客戶端, database對(duì)應(yīng)庫(kù), collection是對(duì)象集合.
對(duì)對(duì)象的操作是爭(zhēng)對(duì)collection來(lái)的.
四 操作
1> 插入
var document = new BsonDocument { { "name", "測(cè)試數(shù)據(jù)1" }, { "type", "大類" }, { "number", 5 }, { "info", new BsonDocument { { "x", 111 }, { "y", 222 } }} }; collection.InsertOne(document);
同理還有InsertMany()
, 鑒于VS高超的智能提示, 一目了然.
2> 查找
上一步插入之后, 通過(guò)find將它查找出來(lái)
find()需要一個(gè)filter參數(shù), 根據(jù)條件查詢
collection.Find(Builders<BsonDocument>.Filter.Empty);
上述表示無(wú)條件查詢, matches everything.
如果有條件的話, 可以從Builders<BsonDocument>.Filter
中選擇, 比如Eq為相等, Lt為小于, Gt大于...顧名思義. 基于VS強(qiáng)大的智能提示, 非常清晰.
舉例條件查詢:
collection.Find(Builders<BsonDocument>.Filter.Eq("name", "測(cè)試數(shù)據(jù)1") & Builders<BsonDocument>.Filter.Lt("number", 6));
多項(xiàng)條件之間的與或關(guān)系, 對(duì)應(yīng)使用&和|符號(hào)
3> 更新
collection.UpdateMany(Builders<BsonDocument>.Filter.Eq("name", "測(cè)試數(shù)據(jù)1"), Builders<BsonDocument>.Update.Set("number", 6));
更新使用UpdateMany(), 同樣支持條件從Builders<BsonDocument>.Filter
中獲取.
更新支持添加新的field, 如:
collection.UpdateMany(Builders<BsonDocument>.Filter.Eq("name", "測(cè)試數(shù)據(jù)1"), Builders<BsonDocument>.Update.Set("number2", 666));
4> 刪除
collection.DeleteMany()
其他幾個(gè)API大同小異
五 BsonDocument到自定義class Object的相互轉(zhuǎn)換
不要引入Json.Net(Newtonsoft.Json)
1> 自定義類型到BsonDocument
擴(kuò)展函數(shù):
entity.ToBsonDocument()
2> BsonDocument到自定義類型
通常是在Find的時(shí)候吧, IFindFluent.As<TEntity>()
轉(zhuǎn)就可以了.
var result = collection .Find((Builders<BsonDocument>.Filter.Lt("number",999) & Builders<BsonDocument>.Filter.Gt("number", 110)) & Builders<BsonDocument>.Filter.Eq("name", "測(cè)試數(shù)據(jù)1")) .OrderBy(x=>x["number"])//排序 .Skip(10)//跳過(guò) .Limit(10)//限制 .As<Bar>()//m=>o .ToList();//像極了Linq吧?
如果不是呢?
var entity = BsonSerializer.Deserialize<Bar>(bson);
用到的自定義class大概長(zhǎng)這樣:
public class Bar { public ObjectId _id { get; set; } public string name { get; set; } public string type { get; set; } public int number { get; set; } public int number2 { get; set; } public BarInfo info { get; set; } public class BarInfo { public int x { get; set; } public int y { get; set; } } }
小感想:
mongodb對(duì)程序員是極友好的, 可以動(dòng)態(tài)變化的結(jié)構(gòu), 讓程序員不再害怕頻繁變動(dòng)的需求.
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)我們的支持。
上一篇:c# WinForm 窗體之間傳值的幾種方式(小結(jié))
欄 目:C#教程
下一篇:C# WPF 通過(guò)委托實(shí)現(xiàn)多窗口間的傳值的方法
本文標(biāo)題:C#簡(jiǎn)單操作MongoDB的步驟全紀(jì)錄
本文地址:http://mengdiqiu.com.cn/a1/C_jiaocheng/5091.html
您可能感興趣的文章
- 01-10C#實(shí)現(xiàn)讀取注冊(cè)表監(jiān)控當(dāng)前操作系統(tǒng)已安裝軟件變化的方法
- 01-10C#實(shí)現(xiàn)簡(jiǎn)單的Login窗口實(shí)例
- 01-10C#實(shí)現(xiàn)判斷當(dāng)前操作用戶管理角色的方法
- 01-10Winform消除button按下出現(xiàn)的虛線簡(jiǎn)單實(shí)現(xiàn)方法
- 01-10C#中DataGridView常用操作實(shí)例小結(jié)
- 01-10C#操作ftp類完整實(shí)例
- 01-10asp.net中XML如何做增刪改查操作
- 01-10winform簡(jiǎn)單緩存類實(shí)例
- 01-10C#一個(gè)簡(jiǎn)單的定時(shí)小程序?qū)崿F(xiàn)代碼
- 01-10C#圓角窗體簡(jiǎn)單實(shí)現(xiàn)方法


閱讀排行
- 1C語(yǔ)言 while語(yǔ)句的用法詳解
- 2java 實(shí)現(xiàn)簡(jiǎn)單圣誕樹的示例代碼(圣誕
- 3利用C語(yǔ)言實(shí)現(xiàn)“百馬百擔(dān)”問(wèn)題方法
- 4C語(yǔ)言中計(jì)算正弦的相關(guān)函數(shù)總結(jié)
- 5c語(yǔ)言計(jì)算三角形面積代碼
- 6什么是 WSH(腳本宿主)的詳細(xì)解釋
- 7C++ 中隨機(jī)函數(shù)random函數(shù)的使用方法
- 8正則表達(dá)式匹配各種特殊字符
- 9C語(yǔ)言十進(jìn)制轉(zhuǎn)二進(jìn)制代碼實(shí)例
- 10C語(yǔ)言查找數(shù)組里數(shù)字重復(fù)次數(shù)的方法
本欄相關(guān)
- 01-10C#通過(guò)反射獲取當(dāng)前工程中所有窗體并
- 01-10關(guān)于ASP網(wǎng)頁(yè)無(wú)法打開的解決方案
- 01-10WinForm限制窗體不能移到屏幕外的方法
- 01-10WinForm繪制圓角的方法
- 01-10C#實(shí)現(xiàn)txt定位指定行完整實(shí)例
- 01-10WinForm實(shí)現(xiàn)仿視頻播放器左下角滾動(dòng)新
- 01-10C#停止線程的方法
- 01-10C#實(shí)現(xiàn)清空回收站的方法
- 01-10C#通過(guò)重寫Panel改變邊框顏色與寬度的
- 01-10C#實(shí)現(xiàn)讀取注冊(cè)表監(jiān)控當(dāng)前操作系統(tǒng)已
隨機(jī)閱讀
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 01-10C#中split用法實(shí)例總結(jié)
- 08-05織夢(mèng)dedecms什么時(shí)候用欄目交叉功能?
- 01-11ajax實(shí)現(xiàn)頁(yè)面的局部加載
- 08-05dedecms(織夢(mèng))副欄目數(shù)量限制代碼修改
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
- 01-10使用C語(yǔ)言求解撲克牌的順子及n個(gè)骰子
- 08-05DEDE織夢(mèng)data目錄下的sessions文件夾有什
- 01-10delphi制作wav文件的方法
- 04-02jquery與jsp,用jquery