mongodb linq查询

本文介绍了使用LINQ进行数据查询的几种常见方法,包括验证表中是否有文档、计算数量、去重查询以及选择查询结果中指定位置的元素等操作。

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

1.Any() 验证表中是否有文档
var result =
    (from c in collection.AsQueryable<C>()
    select c)
    .Any(c => c.X == 1);
// or
var result =
    collection.AsQueryable<C>()
    .Any(c => c.X == 1);
var result =
    (from c in collection.AsQueryable<C>()
    select c)
    .Any();
// or
var result =
    collection.AsQueryable<C>()
    .Any();

2.count()计算数量

var result =
    (from c in collection.AsQueryable<C>()
    select c)
    .Count();
// or
var result =
    collection.AsQueryable<C>()
    .Count();

With a predicate Count returns the number of documents that match the predicate.
var result =
    (from c in collection.AsQueryable<C>()
    select c)
    .Count(c => c.X == 1);
// or
var result =
    collection.AsQueryable<C>()
    .Count(c => c.X == 1);

var result =
    (from c in collection.AsQueryable<C>()
    where c.X == 1
    select c)
    .Count();
// or
var result =
    collection.AsQueryable<C>()
    .Where(c => c.X == 1)
    .Count();

var result =
    collection.AsQueryable<C>()
    .Select(c => c.X)
    .Count(x => x == 1);
3.Distinct 去重查询

ar result =
    (from c in collection.AsQueryable<C>()
    select c.X)
    .Distinct();
// or
var result =
    collection.AsQueryable<C>()
    .Select(c => c.X)
    .Distinct();

var result =
    (from c in collection.AsQueryable<C>()
    select c.A[i])
    .Distinct();
// or
var result =
    collection.AsQueryable<C>()
    .Select(c => c.A[i])
    .Distinct();

4.ElementAt选择查询结果中指定位置的元素,index要是不存在会报错,ElementAtOrDefault不会保存,index不存在,返回null

var result =
    (from c in collection.AsQueryable<C>()
    where c.X > 0
    orderby c.X
    select c)
    .ElementAt(index);
// or
var result =
    collection.AsQueryable<C>()
    .Where(c => c.X > 0)
    .OrderBy(c => c.X)
    .ElementAt(index);

……未完 后续更新

操作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、付费专栏及课程。

余额充值