MongoDB#常用语句

  • 创建TTL索引(自动删除过期数据)

db.xxx_collection.createIndex({ createTime: 1 }, { expireAfterSeconds: 1 * 24 * 60 * 60 * 1000 });

  • 查询JavaScript函数(mongosh)

db.system.js.find

  • 查询document条数

db.getCollection('xxx').countDocuments({})

  • 根据_id查询

{'_id': ObjectId('xxx')}

  • in查询

{ field_name: { $in: [ "field_value1", "field_value2" ] } }

  • 时间范围查询

{"updateTime": {gte: ISODate('2024-01-01'), lte: ISODate('2024-12-12')}}

  • like查询

{ field_name: { $regex: /xxx/ } }

  • aggregate查询
sql 复制代码
db.myCollection.aggregate([
  {
    $group: {
      _id: "$groupId", // 根据groupId分组
      count: { $sum: 1 }, // 分组内文档数量累加,并存储到count字段中
      documents: { $push: "$$ROOT" }  // 将原始文档存储到 documents 数组中
    }
  },
  {
    $match: {
      count: { $gt: 2 } // 过滤出count字段值大于2的分组
    }
  }
]);
// $group聚合操作默认内存中执行,超出限制可配置allowDiskUse使用磁盘存储临时数据
相关推荐
x***38163 分钟前
从MySQL迁移到PostgreSQL的完整指南
数据库·mysql·postgresql
p***233612 分钟前
【MySQL】CAST()在MySQL中的用法以及其他常用的数据类型转换函数
数据库·mysql
O***Z61612 分钟前
【MySQL】表的基本操作
数据库·mysql·oracle
5***g29813 分钟前
MySQL 数据库连接池爆满问题排查与解决
android·数据库·mysql
l***217814 分钟前
MySql-9.1.0安装详细教程(保姆级)
数据库·mysql
v***Y8916 分钟前
SQL 中 COUNT 的用法详解
数据库·sql
I***t71619 分钟前
【MYSQL】聚合查询、分组查询、联合查询
数据库·sql·mysql
f***147721 分钟前
MySQL -- 约束
数据库·mysql·oracle
0***863330 分钟前
【SQL技术】不同数据库引擎 SQL 优化方案剖析
数据库·sql
s***353031 分钟前
关于Mysql 中 Row size too large (> 8126) 错误的解决和理解
数据库·mysql