使用C#连接并读取MongoDB数据库
作者:.NET开发菜鸟 时间:2024-01-15 17:12:13
在上篇文章中,讲解了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();
}
}
}
程序运行结果如下图所示:
来源:https://www.cnblogs.com/dotnet261010/p/8406120.html
标签:C#,MongoDB,数据库
0
投稿
猜你喜欢
Python 多线程知识点总结及实例用法
2022-04-27 13:19:49
Pandas中Series的属性,方法,常用操作使用案例
2021-11-22 05:00:47
Vue开发之封装上传文件组件与用法示例
2024-05-10 14:09:44
Python的numpy库中将矩阵转换为列表等函数的方法
2021-06-19 12:18:21
Python推导式简单示例【列表推导式、字典推导式与集合推导式】
2021-08-04 08:23:40
关于超级链接的一些问题
2007-12-07 14:00:00
python项目对接钉钉SDK的实现
2021-09-18 22:21:29
Golang并发编程之Channel详解
2024-05-09 14:58:42
关于pytorch处理类别不平衡的问题
2023-04-08 19:11:56
利用mysql的inet_aton()和inet_ntoa()函数存储IP地址的方法分享
2024-01-16 17:28:39
Python2.X/Python3.X中urllib库区别讲解
2022-08-03 01:45:39
Python中的np.random.seed()随机数种子问题及解决方法
2023-01-15 20:14:02
Go实现MD5加密的三种方法小结
2024-02-08 03:47:37
mysql 分页优化解析
2024-01-15 00:33:40
一文秒懂pandas中iloc()函数
2023-07-31 18:20:42
如何增强网站数据库Access文件的安全性
2008-11-13 16:58:00
SQL Server数据库安装时常见问题解决方案集锦
2024-01-19 05:05:57
Python的Bottle框架中返回静态文件和JSON对象的方法
2023-11-07 20:14:41
Python创建xml文件示例
2023-03-08 22:41:45
详解如何基于Pyecharts绘制常见的直角坐标系图表
2022-07-08 05:18:31