MongoDB常用语句

1.只统计记录总数:

复制代码
let result = await CorrectionRecordModel.countDocuments(db);

2.数组遍历,循环体中可以有调用异步函数:

复制代码
            for(let item of result2){
                if(item && Tool.checkNotEmptString(item.auth_id) && (item.status !== 1)){
                    await apiUtil.modifyData(EstateDetailModel, {auth_id: item.auth_id}, {
                        status: 1, 
                    });
                }
            }

3.遍历数组,循环体中不可以调用异步函数:

复制代码
                space_service_labels.forEach(item =>{
                    let name = Tool.getEnumValue(14, item);
                    if(Tool.checkNotEmptString(name)){
                        space_service_labels_names.push(name);
                    }
                });

4.对数组,投影出指定对象组成新数组:

复制代码
let ids = list.map(item => item.id);

5.查询出指定距离内的记录:

复制代码
                    db.location = {
                        $near: {
                            $geometry: currentLocation,
                            $maxDistance: distance1
                        }
                    };

6.对查询出的结果数组,按照指定字段再排序:

复制代码
// 按照每组内的记录数降序排序
                groupedArray.sort((a, b) => b.count - a.count);

7.数据查询条件中对结果进行排序(-1从倒序,1正序):

复制代码
db.sort({ update_time : -1 })

8.聚合语句:

复制代码
        let result = await ApiUserPushModel.aggregate([
            {
                $match: {
                    user_id:,
                    create_time: {
                        $gte: start_time,
                        $lte: end_time
                    },
                }
            },
            {
                $group: {
                    _id: '$batch_number',
                    push_count: { $sum: 1 },
                    push_title: { $first: '$push_title' },
                    commission : { $first: '$commission' },
                    notes : { $first: '$notes' },
                    create_time : { $first: '$create_time' },
                    batch_number : { $first: '$batch_number' },
                    data: { $push: '$$ROOT' },
                    
                }
            },
            {
                $project:{
                    _id:0
                }
            }
            
        ]);
  1. 查询是否存在:

    复制代码
             const exist = await UserModel.exists({
                 user_name: user_name
             });
相关推荐
贾斯汀玛尔斯27 分钟前
每天学一个算法--LSM-Tree(Log-Structured Merge Tree)
java·算法·lsm-tree
S1998_1997111609•X3 小时前
论当今社会主义与人文关怀人格思想下的恶意仿生注入污染蜜罐描述进行函数值非法侵入爬虫的咼忄乂癿〇仺⺋.
数据库·网络协议·百度·ssh·开闭原则
倔强的石头_4 小时前
kingbase备份与恢复实战(六)—— 备份自动化与保留策略:Windows任务计划+日志追溯
数据库
轻刀快马5 小时前
别被 ORM 框架宠坏了:从一场“订单消失”悬案,看懂 MySQL 为什么要强推 InnoDB
数据库·mysql
浅念-5 小时前
刷穿LeetCode:BFS 解决 Flood Fill 算法
数据结构·c++·算法·leetcode·职场和发展·bfs·宽度优先
做cv的小昊5 小时前
【TJU】研究生应用统计学课程笔记(8)——第四章 线性模型(4.1 一元线性回归分析)
笔记·线性代数·算法·数学建模·回归·线性回归·概率论
贾斯汀玛尔斯6 小时前
每天学一个算法--倒排索引(Inverted Index)
算法·inverted-index
小e说说6 小时前
打破偏科困境:这些学习软件助孩子重燃学习热情
算法
后端漫漫6 小时前
Redis 客户端工具体系
数据库·redis·缓存