MongoDB从不懂到装懂其二(C#操作MongoDB)


上一篇文档讲述了在命令窗口下的MongoDB的相关操作,这一篇讲述C#语言环境下MongoDB的使用。


先附上实例代码:http://download.csdn.net/detail/sinat_22013331/9575331

注意在运行这个例子的时候,首先要按照例子中的数据库名称和表单名称来新建数据库和表单。同时开启数据库服务器。



具体使用时,先要下载MongoDB驱动文件,下载地址是:https://github.com/mongodb/mongo-csharp-driver/releases

驱动下载之后,在文件中添加引用就行了。下面详细讲解使用方法。


step 1:数据库基本设置,获取数据库和数据库服务器实例


这里可以新建一个类,专门用来放置数据库的一些设置细节。如下所示,每一条语句的作用都作了说明。

    internal sealed class MongoDB
    {
        //数据库所在主机的端口
        private readonly int MONGO_CONN_PORT = 27017;

        //设置连接超时15秒
        private readonly int CONNECT_TIME_OUT = 15;

        //设置最大连接数
        private readonly int MAXConnectionPoolSize = 99;

        //设置最小连接数
        private readonly int MINConnectionPoolSize = 1;

        /// <summary>
        /// 获得数据库实例
        /// </summary>
        /// <param name="MONGO_CONN_HOST">数据库主机链接</param>
        /// <param name="DB_Name">数据库名称</param>
        /// <returns>数据库实例</returns>
        public MongoDatabase GetDataBase(string MONGO_CONN_HOST, string DB_Name)
        {
            MongoClientSettings mongoSetting = new MongoClientSettings();

            mongoSetting.ConnectTimeout = new TimeSpan(CONNECT_TIME_OUT * TimeSpan.TicksPerSecond);  //设置超时连接

            mongoSetting.Server = new MongoServerAddress(MONGO_CONN_HOST, MONGO_CONN_PORT);  //设置数据库服务器

            mongoSetting.MaxConnectionPoolSize = MAXConnectionPoolSize;  //设置最大连接数
            mongoSetting.MinConnectionPoolSize = MINConnectionPoolSize;  //设置最小连接数

            MongoClient client = new MongoClient(mongo
  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
操作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); }
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值