C#操作MongoDB,看我这一篇就够了!

一、准备工作

工欲善其事必先利其器,首先呢咱们得下载好C#程序里面可以驱动mongodb的组件:

走起官网:C#操作mongodb组件下载

菜鸟教程也上一上:mongodb菜鸟教程

dll下载下来之后有这几个,都引用上,不要省,哈哈!个人还是习惯直接下载下来,不走Nget的模式,那玩意菜鸟学不会。

为啥要加上xml呢,这你就不懂了,你难道没发现加了之后使用方法的时候,有了说明了么?就是这么优秀的一个操作。


二、开始实操增删改查

做好准备工作,下面咱们开始实操,把增删改查给你走一遍,看好喽,打起精神!

话不多话,咱先上代码,以后看到只说不做,特别是不放完整源代码的博主,咱们就得讲他耍流氓,咱可不做这类型的人,直接贴代码,优秀的人做事一向就是这么直接

using System;
using System.Collections.Generic;
using System.Linq;
using System.Linq.Expressions;
using System.Text;
using MongoDB.Bson;
using MongoDB.Bson.Serialization.Attributes;
using MongoDB.Driver;

namespace MongoDbSpider
{
    /// <summary>
    /// MongoDb 数据库操作类
    /// </summary>
    public class MongoDbHelper
    {
        /// <summary>
        /// 数据库对象
        /// </summary>
        private IMongoDatabase _dataBase;

        /// <summary>
        /// 构造函数
        /// </summary>
        /// <param name="conStrMdb">连接字符串</param>
        public MongoDbHelper(string conStrMdb)
        {
            this._dataBase = GetDb(conStrMdb);
        }

        /// <summary>
        /// 若没有,根据传入的数据库名字来生成对应的数据库名,否则,返回db
        /// </summary>
        /// <param name="conStrMdb">数据库连接</param>
        /// <returns></returns>
        public IMongoDatabase GetDb(string conStrMdb)
        {
            var db = new MongoClient(conStrMdb).GetDatabase(new MongoUrlBuilder(conStrMdb).DatabaseName);
            return db;
        }

        /// <summary>
        /// 创建集合对象
        /// </summary>
        /// <param name="collName">集合名称</param>
        ///<returns>集合对象</returns>
        private IMongoCollection<T> GetColletion<T>(string collName)
        {
            return _dataBase.GetCollection<T>(collName);
        }

        /// <summary>
        /// 获取指定数据库集合中的所有的文档
        /// </summary>
        /// <typeparam name="T"></typeparam>
        /// <param name="tableName">表名</param>
        /// <returns></returns>
        public List<T> FindAll<T>(string tableName)
        {
            List<T> list = new List<T>();
            try
            {
                var collection = GetColletion<T>(collName: tableName);
                FilterDefinition<T> filter =
评论 18
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值