封装一个MongoDB的 asp.net 链接类

本文介绍了一个封装了Mongo和MongoDatabase的类MyMongoDb,用于简化MongoDB的操作。通过构造函数和UseDb方法,可以方便地创建连接并切换数据库。此外,还提供了获取当前连接数据库的集合的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

using System;
using System.Collections.Generic;
using System.Linq;
using MongoDB;


/// <summary>
/// 对Mongo和MongoDatabase的包装类
/// </summary>
public class MyMongoDb : IDisposable
{
    private Mongo _mongo;
    private IMongoDatabase _db;
    private static string connectionString = "Server=127.0.0.1;mydb";
    private static readonly string _connectionString = connectionString.Split(';')[0];// "Server=127.0.0.1";
    private static readonly string _dbName = connectionString.Split(';')[1];



    public MyMongoDb()
        : this(_connectionString, _dbName)
    {
    }

    public MyMongoDb(string dbName)
        : this(_connectionString, dbName)
    {
    }

	/// <summary>
	/// 构造函数。根据指定连接字符串和数据库名
	/// </summary>
	/// <param name="connectionString">连接字符串</param>
	/// <param name="dbName">数据库名,可为空,但必须在任何操作数据库之前要调用UseDb()方法</param>
	public MyMongoDb(string connectionString, string dbName)
	{
		if( string.IsNullOrEmpty(connectionString) )
			throw new ArgumentNullException("connectionString");

		_mongo = new Mongo(connectionString);

		// 立即连接 MongoDB
		_mongo.Connect();

		if( string.IsNullOrEmpty(dbName) == false )
			_db = _mongo.GetDatabase(dbName);
	}

	/// <summary>
	/// 切换到指定的数据库
	/// </summary>
	/// <param name="dbName"></param>
	/// <returns></returns>
	public IMongoDatabase UseDb(string dbName)
	{
		if( string.IsNullOrEmpty(dbName) )
			throw new ArgumentNullException("dbName");

		_db = _mongo.GetDatabase(dbName);
		return _db;
	}

	/// <summary>
	/// 获取当前连接的数据库
	/// </summary>
	public IMongoDatabase CurrentDb
	{
		get
		{
			if( _db == null )
				throw new Exception("当前连接没有指定任何数据库。请在构造函数中指定数据库名或者调用UseDb()方法切换数据库。");

			return _db;
		}
	}

	/// <summary>
	/// 获取当前连接数据库的指定集合【依据类型】
	/// </summary>
	/// <typeparam name="T"></typeparam>
	/// <returns></returns>
	public IMongoCollection<T> GetCollection<T>() where T : class
	{
		return this.CurrentDb.GetCollection<T>();
	}

	/// <summary>
	/// 获取当前连接数据库的指定集合【根据指定名称】
	/// </summary>
	/// <typeparam name="T"></typeparam>
	/// <param name="name">集合名称</param>
	/// <returns></returns>
	public IMongoCollection<T> GetCollection<T>(string name) where T : class
	{
		return this.CurrentDb.GetCollection<T>(name);
	}

	public void Dispose()
	{
		if( _mongo != null ) {
			_mongo.Dispose();
			_mongo = null;
		}
	}	
}


使用链接类

        public void Insert(USER user)
        {
            using (MyMongoDb mdb = new MyMongoDb())
            {
                var collection = mdb.GetCollection<USER>();

                collection.Insert(user);
            }
        }


 

操作monodb的c#封装,调用非常方便,可以继承,功能包括: 1、所有数据库操作 2、前台表格数据获取 public List GetList(List lstColName, Document query, JqGridParam jqParam, ref int count),封装了通用的获取前台表格数据的方法,将在工程中减少大量数据库访问代码,有了这个后对前台表格查询我们可以不用在Control里使用linq或者封装在Model里然后对前台定义视图了,使用如下: try { JqGridParam jqParam = new JqGridParam(); jqParam.page = 1; jqParam.rows = 1000; MemberOper memOper = new MemberOper(); MongoBasicOper monOper = new MongoBasicOper(DTName.GROUP_MEMBER); int count = 0; //过滤条件 Document query = new Document(); if (!string.IsNullOrEmpty(find)) { MongoRegex reg = new MongoRegex(".*" + find + ".*"); query.Add(DColName.Name, reg); } query.Add(DColName.GroupId, g); Document[] docStatus = new Document[] { new Document(DColName.Status, RowStatus.Pass), new Document(DColName.Status, RowStatus.Admin) }; query.Add("$or", docStatus); //查询列 List lstColName = new List(); lstColName.Add(DColName.UserId); lstColName.Add(DColName.UserName); //查询数据 var lstRes = monOper.GetListEx(lstColName, query, jqParam, ref count); //转换返回值 JqGrid jg = new JqGrid(); if (count == 0) { return Json(jg.toNull(jqParam), JsonRequestBehavior.AllowGet); } var jsonData = jg.toJson(jqParam, count, lstRes, lstColName); jsonData.param = g; return Json(jsonData, JsonRequestBehavior.AllowGet); } catch (Exception e) { return Json(e.Message, JsonRequestBehavior.AllowGet); }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值