使用C#代碼連接並讀取MongoDB數據庫

這篇文章中講解如何使用C#程序連接到MongoDB數據庫,並且讀取裏面的文檔。

一、新建項目

新建控制檯程序,命名爲“MongoDBDemo”

二、使用NuGet添加MongoDB

1、在項目上右鍵,選擇“管理NuGet程序包”

2、在彈出的對話框中輸入“MongoDB”並搜索

3、這裏選擇安裝MongoDB.Driver,安裝過程如下:

4、查看引用

安裝完成以後,查看項目的引用,發現MongoDB使用到的幾個dll文件都已經添加到引用中。

三、在配置文件中添加MongoDB數據庫的連接字符串

連接到MongoDB的test數據庫,配置文件配置如下所示:

四、測試程序

實例代碼如下所示:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using MongoDB.Driver;
using MongoDB.Bson;
using System.Configuration;

namespace MongoDBDemo
{
    class Program
    {
        // 定義接口
        protected static IMongoDatabase _database;
        // 定義客戶端
        protected static IMongoClient _client;
        static void Main(string[] args)
        {
            // 定義要查詢的集合名稱
            const string collectionName = "Student";
            // 讀取連接字符串
            string strCon = ConfigurationManager.ConnectionStrings["mongodbConn"].ConnectionString;
            var mongoUrl = new MongoUrlBuilder(strCon);
            // 獲取數據庫名稱
            string databaseName = mongoUrl.DatabaseName;
            // 創建並實例化客戶端
            _client = new MongoClient(mongoUrl.ToMongoUrl());
            //  根據數據庫名稱實例化數據庫
            _database = _client.GetDatabase(databaseName);
            // 根據集合名稱獲取集合
            var collection= _database.GetCollection<BsonDocument>(collectionName);
            var filter = new BsonDocument();
            // 查詢集合中的文檔
            var list = Task.Run(async () => await collection.Find(filter).ToListAsync()).Result;
            // 循環遍歷輸出
            list.ForEach(p =>
            {
                Console.WriteLine("編號:" + p["stuId"] + ",姓名:" + p["name"].ToString() + ",年齡:"+p["age"].ToString() + ",課程:"+p["subject"].ToString() + ",成績:"+p["score"].ToString());
            });

            Console.ReadKey();
        }
    }
}

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

 

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章