返回顶部
首页 > 资讯 > 数据库 >表单生成器(Form Builder)之mongodb表单数据查询——返回分页数据和总条数 - du
  • 225
分享到

表单生成器(Form Builder)之mongodb表单数据查询——返回分页数据和总条数 - du

摘要

  上一篇笔记将开始定义的存储结构处理了一下,将FORMItems数组中的表单项都拿到mongoDB document的最外层,和以前的关系型数据类似,之不过好多列都是动态的,不固定,不过这并没有什么影响。结果就是方便我们更好的查询和统计;

  上一篇笔记将开始定义的存储结构处理了一下,将FORMItems数组中的表单项都拿到mongoDB document的最外层,和以前的关系型数据类似,之不过好多列都是动态的,不固定,不过这并没有什么影响。结果就是方便我们更好的查询和统计;还有一点就是转换之后从服务器端返回客户端的对象也是如此,这样更加方便了获取每个表单项的值(例如渲染列表)。

  我们的好的应用场景都是分页加载,好多地方都需要知道总的条数。以前呢是弄了两个api:一个是获取查询结果;一个是获取条数。为了这样一个功能要多发送一个API觉得有点浪费,之后便上网查了一下,这个问题前辈门已经遇到过了并且解决了,这里只是记录一下。我找到了几种处理方式,下面一一介绍一下。

  第一种

//        $facet    New in version 3.4.
db.getCollection("FormInstace").aggregate([
  {
    $facet: {
        totalCount: [{ $match:{FormId:"507048044944691000"} },{ $count: "totalCount" }],
      results: [{ $match:{FormId:"507048044944691000"} }]
    }
  }
]);

  方案二

//    方案2:
async function getQuery() {
  let query = await db.collection.find({}).skip(5).limit(5); // returns last 5 items in db
  let countTotal = await query.count() // returns 10-- will not take `skip` or `limit` into consideration
  let countWithConstraints = await query.count(true) // returns 5 -- will take into consideration `skip` and `limit`
  return { query, countTotal } 
}

  等待截图……

  以上两个方案都来自于:https://stackoverflow.com/questions/21803290/get-a-count-of-total-documents-with-monGodb-when-using-limit

  方案三

//    方案3:
db.getCollection("FormInstace").aggregate([
    {
        $match: {
            "FormItems.key": { $ne: null }
        }
    },
    {
        $addFields: {
            FormValueObj: {
                $arrayToObject: {
                    $map: {
                        input: "$FormItems",
                        as: "field",
                        in: [ "$$field.key", "$$field.value" ]
                    }
                }
            }
        }
    },
    {
      $replaceRoot: { newRoot: { $mergeObjects: [ "$FormValueObj", "$$ROOT" ] } }
    },
    {
        $project: {
            FormItems:0,
            FormValueObj:0
        }
    },
    {
        $match:{FormId:"507048044944691000"}
    },
    { 
        $group: {
            _id: null,
            count: { $sum: 1 },
            results: { $push: "$$ROOT" }
        }     
    },
    {
        $project:{_id:0,count:1, results: { $slice: [ "$results", 20, 20 ] }}
    }
]);

  方案三参考的是:Https://medium.com/@kheengz/mongodb-aggregation-paginated-results-and-a-total-count-using-d2e23a00f5d5 但是上面的连接中也包括了这种方式……不管怎么说达到了我们想要的结果,并且支持分页!!!就是时间还是有点长,以后看看还能不能优化,如果有哪位大神有更好的方式,请告知,在这里表示感谢……

您可能感兴趣的文档:

--结束END--

本文标题: 表单生成器(Form Builder)之mongodb表单数据查询——返回分页数据和总条数 - du

本文链接: https://lsjlt.com/news/2037.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作