在上篇文章中,講解了MongoDB的基本操作,包括增、刪、改、查,但是這些操作都是在命令行模式下進行的,這篇文章中講解如何使用C#程序連接到MongoDB數據庫,並且讀取里面的文檔。
一、新建項目
新建控制台程序,命名為“MongoDBDemo”
二、使用NuGet添加MongoDB
1、在項目上右鍵,選擇“管理NuGet程序包”
2、在彈出的對話框中輸入“MongoDB”並搜索
3、這里選擇安裝MongoDB.Driver,安裝過程如下:
4、查看引用
安裝完成以后,查看項目的引用,發現MongoDB使用到的幾個dll文件都已經添加到引用中。
三、在配置文件中添加MongoDB數據庫的連接字符串
連接到MongoDB的test數據庫,配置文件配置如下所示:
四、測試程序
實例代碼如下所示:
1 using System; 2 using System.Collections.Generic; 3 using System.Linq; 4 using System.Text; 5 using System.Threading.Tasks; 6 using MongoDB.Driver; 7 using MongoDB.Bson; 8 using System.Configuration; 9 10 namespace MongoDBDemo 11 { 12 class Program 13 { 14 // 定義接口 15 protected static IMongoDatabase _database; 16 // 定義客戶端 17 protected static IMongoClient _client; 18 static void Main(string[] args) 19 { 20 // 定義要查詢的集合名稱 21 const string collectionName = "Student"; 22 // 讀取連接字符串 23 string strCon = ConfigurationManager.ConnectionStrings["mongodbConn"].ConnectionString; 24 var mongoUrl = new MongoUrlBuilder(strCon); 25 // 獲取數據庫名稱 26 string databaseName = mongoUrl.DatabaseName; 27 // 創建並實例化客戶端 28 _client = new MongoClient(mongoUrl.ToMongoUrl()); 29 // 根據數據庫名稱實例化數據庫 30 _database = _client.GetDatabase(databaseName); 31 // 根據集合名稱獲取集合 32 var collection= _database.GetCollection<BsonDocument>(collectionName); 33 var filter = new BsonDocument(); 34 // 查詢集合中的文檔 35 var list = Task.Run(async () => await collection.Find(filter).ToListAsync()).Result; 36 // 循環遍歷輸出 37 list.ForEach(p => 38 { 39 Console.WriteLine("編號:" + p["stuId"] + ",姓名:" + p["name"].ToString() + ",年齡:"+p["age"].ToString() + ",課程:"+p["subject"].ToString() + ",成績:"+p["score"].ToString()); 40 }); 41 42 Console.ReadKey(); 43 } 44 } 45 }
程序運行結果如下圖所示: