【MongoDB】C# MongoDB的常用操作

3 篇文章 0 订阅

最近在弄有关MongoDB存储查询订单的功能,再此做个记录

这里使用的是 MongoDB.Driver 

1.连接数据库:

var strconn = "mongodb://帐号:密码@数据库链接:端口";
var mongoUrl = MongoUrl.Create(strconn);
var MongoClient client = new MongoClient(mongoUrl);                            
var db = client.GetDatabase("dbName");//获取数据库                           
var table = db.GetCollection<T>("tableName");//获取集合(泛型)

2.先介绍几个东西

Builders<Publisher_Order_Dto_MongoDB>.Filter:筛选数据用到,查询或者更新数据等会用到,有很多 操作符

Builders<Publisher_Order_Dto_MongoDB>.Update:更新数据用到

Builders<Publisher_Order_Dto_MongoDB>.Projection:指定查询字段或者不要查询某个字段时用到,这里主要用于过滤掉 _id

3.插入数据

table.InsertMany(List);//批量插入数据
table.InsertOne(item);//插入一条

4.更新数据

A.批量查询已有的数据再更新(目前只找到这种方式来更新)

var filter = Builders<T>.Filter;//查询条件用到
var Update = Builders<T>.Update;//更新数据用到
var Id_List = List.Select(x => x.trade_id).ToList();//订单id
var where = filter.And(filter.Eq("userId", userId), filter.In("trade_id",Id_List));//查询(这里 类似 select * from table where userId=userId and trade_id in(xxx,xxx,xxx) )
//指定查询字段
var fieldList = new List<ProjectionDefinition<T>>();
fieldList.Add(Builders<T>.Projection.Exclude("_id"));//不包含_id
var projection = Builders<T>.Projection.Combine(fieldList);

//更新操作-先查询出已有的数据,再循环更新
var data_update = table.Find(where).Project<T>(projection);//插入设置的条件进行查询
data_update.ForEachAsync((item) =>
{
    var updateItem = List.Where(x => x.trade_id == item.trade_id).FirstOrDefault();
    if (updateItem != null)
     {
       //更新操作
 var query = filter.And(filter.Eq("userId", userId), filter.Eq("trade_id", item.trade_id));
          var updateSet = Update
                          .Set("tk_status", updateItem.tk_status)//设置要更新的字段和数据
                          .Set("tk_status_name", updateItem.tk_status_name)
                          .Set("tk_earning_time", updateItem.tk_earning_time);
          table.UpdateOne(query, updateSet);//更新一条数据
     }

});

B.直接按条件来批量更新数据

table.UpdateMany(query, updateSet);//批量

5.删除数据

var filter = Builders<T>.Filter;//查询条件用到:可以根据各个操作符组合
table.DeleteMany(filter);//批量
table.DeleteOne(filter);//一条

6.查询数据

7.索引

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
操作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
发出的红包

打赏作者

沃祐进先生

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值