使用C#連接并讀取MongoDB數(shù)據(jù)庫
在上篇文章中,講解了MongoDB的基本操作,包括增、刪、改、查,但是這些操作都是在命令行模式下進(jìn)行的,這篇文章中講解如何使用C#程序連接到MongoDB數(shù)據(jù)庫,并且讀取里面的文檔。
一、新建項(xiàng)目
新建控制臺程序,命名為“MongoDBDemo”

二、使用NuGet添加MongoDB
1、在項(xiàng)目上右鍵,選擇“管理NuGet程序包”

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

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

4、查看引用
安裝完成以后,查看項(xiàng)目的引用,發(fā)現(xiàn)MongoDB使用到的幾個(gè)dll文件都已經(jīng)添加到引用中。

三、在配置文件中添加MongoDB數(shù)據(jù)庫的連接字符串
連接到MongoDB的test數(shù)據(jù)庫,配置文件配置如下所示:

四、測試程序
實(shí)例代碼如下所示:
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);
// 獲取數(shù)據(jù)庫名稱
string databaseName = mongoUrl.DatabaseName;
// 創(chuàng)建并實(shí)例化客戶端
_client = new MongoClient(mongoUrl.ToMongoUrl());
// 根據(jù)數(shù)據(jù)庫名稱實(shí)例化數(shù)據(jù)庫
_database = _client.GetDatabase(databaseName);
// 根據(jù)集合名稱獲取集合
var collection= _database.GetCollection<BsonDocument>(collectionName);
var filter = new BsonDocument();
// 查詢集合中的文檔
var list = Task.Run(async () => await collection.Find(filter).ToListAsync()).Result;
// 循環(huán)遍歷輸出
list.ForEach(p =>
{
Console.WriteLine("編號:" + p["stuId"] + ",姓名:" + p["name"].ToString() + ",年齡:"+p["age"].ToString() + ",課程:"+p["subject"].ToString() + ",成績:"+p["score"].ToString());
});
Console.ReadKey();
}
}
}程序運(yùn)行結(jié)果如下圖所示:

到此這篇關(guān)于使用C#連接并讀取MongoDB數(shù)據(jù)庫的文章就介紹到這了。希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
c# Linq distinct不會調(diào)用Equals方法詳解
這篇文章主要介紹了c# Linq distinct不會調(diào)用Equals方法詳解,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-12-12
Winform實(shí)現(xiàn)調(diào)用asp.net數(shù)據(jù)接口實(shí)例
這篇文章主要介紹了Winform實(shí)現(xiàn)調(diào)用asp.net數(shù)據(jù)接口的方法,以實(shí)例的形式講述了數(shù)據(jù)接口及反射辨別響應(yīng)的實(shí)現(xiàn)方法,具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2014-10-10
C#使用Socket快速判斷數(shù)據(jù)庫連接是否正常的方法
這篇文章主要介紹了C#使用Socket快速判斷數(shù)據(jù)庫連接是否正常的方法,涉及C#中socket操作的相關(guān)技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2015-04-04
c#中string的特性介紹及注意事項(xiàng)小結(jié)
這篇文章主要給大家介紹了關(guān)于c#中string的特性介紹及注意事項(xiàng)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用c#具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-11-11
C#連接SQL?Sever數(shù)據(jù)庫詳細(xì)圖文教程
C#是Microsoft公司為.NET Framework推出的重量級語言,和它搭配最完美的數(shù)據(jù)庫無疑就是Microsoft SQL Server了,下面這篇文章主要給大家介紹了關(guān)于C#連接SQL?Sever數(shù)據(jù)庫的詳細(xì)圖文教程,需要的朋友可以參考下2023-06-06
C#常用多線程(線程同步,事件觸發(fā),信號量,互斥鎖,共享內(nèi)存,消息隊(duì)列)
這篇文章主要介紹了C#常用多線程(線程同步,事件觸發(fā),信號量,互斥鎖,共享內(nèi)存,消息隊(duì)列),本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-09-09

