首頁 > 軟體

使用C#連線並讀取MongoDB資料庫

2022-03-07 19:08:01

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

程式執行結果如下圖所示:

到此這篇關於使用C#連線並讀取MongoDB資料庫的文章就介紹到這了。希望對大家的學習有所幫助,也希望大家多多支援it145.com。


IT145.com E-mail:sddin#qq.com