MongoDB(六):使用C#代碼連接並讀取MongoDB數據庫


在上篇文章中,講解了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 }

 程序運行結果如下圖所示:


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM