一、添加MongoDB引用
想要在C#中使用MongoDB,首先安裝支持MongoDB的C#版的驅動。
利用MongoDB官方發布的C#驅動,可通過網絡下載或nuget安裝,得到MongoDB相關的dll,添加到項目中引用。
https://docs.mongodb.com/drivers/csharp/
1、通過NuGet方式添加
第一步:在項目中右鍵,選擇管理NuGet管理包
第二步:搜索MongoDB,選擇MongoDB.Driver添加,我這里已經添加過了所以沒有添加按鈕
通過這兩步,會在項目中自動添加MongoDB.Bson(序列化、Json相關)、MongoDB.Driver(驅動程序)、MongoDB.Driver.Core等引用
二、使用方法
1、連接數據庫
在連接數據庫之前,請確保MongoDB數據庫服務已經啟動。
using MongoDB.Bson; using MongoDB.Driver; //1.連接字符串(mongodb數據庫默認端口為:27017) string connStr = "mongodb://127.0.0.1:27017"; //2.創建連接MongoClient實例實際上代表了一個到數據庫的連接池,即使有多個線程,也只需要一個MongoClient類的實例 var client = new MongoClient(connStr); //3.使用client的GetDatabase方法獲取數據庫,即使該數據庫不存在,也會自動創建; IMongoDatabase db = client.GetDatabase("test");
2、操作數據
三個對象, client是連接數據庫的客戶端, database對應庫, collection是對象集合。對對象的操作是針對collection集合。
//4.獲取數據集 collection;BsonDocument是在數據沒有預先定義好的情況下使用的。 IMongoCollection<BsonDocument> collection = db.GetCollection<BsonDocument>("runoob1"); //5.插入一條數據; var document = new BsonDocument { { "id", 2 }, { "name", "aa" } }; collection.InsertOne(document); //6.查詢數據1 var res = collection.Find(new BsonDocument()).ToList(); //查詢整個數據集 foreach (var item in res) { Console.WriteLine(item); } //6.查詢數據2 var res_a = collection.Find(new BsonDocument()).FirstOrDefault(); //查詢當前數據集的第一條數據,沒有則返回null Console.WriteLine(res_a); //6.升序降序查詢3: var sort_ascending = Builders<BsonDocument>.Sort.Ascending("id"); //根據id升序 var sort_descending = Builders<BsonDocument>.Sort.Descending("id"); //根據id降序 var res_c = collection.Find(Builders<BsonDocument>.Filter.Lt("id", 10) & Builders<BsonDocument>.Filter.Gte("id", 2)).Limit(50).Sort(sort_ascending).ToCursor(); //查詢id小於10,大於2的數據 foreach (var item in res_c.ToEnumerable()) { Console.WriteLine(item); } //7.更新數據,更新支持添加新的field, 如: collection.UpdateMany(Builders<BsonDocument>.Filter.Eq("id", 2), Builders<BsonDocument>.Update.Set("name", "hello")); //將id字段為2的名字都改為“hello”; //8.刪除 collection.DeleteMany(Builders<BsonDocument>.Filter.Eq("id", 2));
mongodb對程序員是極友好的, 可以動態變化的結構, 讓程序員不再害怕頻繁變動的需求。