MongoDB 基本查询语句

基本查询

  1. 查询所有文档

    sh 复制代码
    db.collection.find()

    示例:

    sh 复制代码
    db.users.find()
  2. 按条件查询文档

    sh 复制代码
    db.collection.find({ key: value })

    示例:

    sh 复制代码
    db.users.find({ age: 25 })
  3. 查询并格式化输出

    sh 复制代码
    db.collection.find().pretty()

    示例:

    sh 复制代码
    db.users.find().pretty()

条件操作符

  1. 等于 ($eq)

    sh 复制代码
    db.collection.find({ key: { $eq: value } })

    示例:

    sh 复制代码
    db.users.find({ age: { $eq: 25 } })
  2. 不等于 ($ne)

    sh 复制代码
    db.collection.find({ key: { $ne: value } })

    示例:

    sh 复制代码
    db.users.find({ age: { $ne: 25 } })
  3. 大于 ($gt)

    sh 复制代码
    db.collection.find({ key: { $gt: value } })

    示例:

    sh 复制代码
    db.users.find({ age: { $gt: 25 } })
  4. 大于等于 ($gte)

    sh 复制代码
    db.collection.find({ key: { $gte: value } })

    示例:

    sh 复制代码
    db.users.find({ age: { $gte: 25 } })
  5. 小于 ($lt)

    sh 复制代码
    db.collection.find({ key: { $lt: value } })

    示例:

    sh 复制代码
    db.users.find({ age: { $lt: 25 } })
  6. 小于等于 ($lte)

    sh 复制代码
    db.collection.find({ key: { $lte: value } })

    示例:

    sh 复制代码
    db.users.find({ age: { $lte: 25 } })

逻辑操作符

  1. 与 ($and)

    sh 复制代码
    db.collection.find({ $and: [ { key1: value1 }, { key2: value2 } ] })

    示例:

    sh 复制代码
    db.users.find({ $and: [ { age: { $gt: 25 } }, { name: "Alice" } ] })
  2. 或 ($or)

    sh 复制代码
    db.collection.find({ $or: [ { key1: value1 }, { key2: value2 } ] })

    示例:

    sh 复制代码
    db.users.find({ $or: [ { age: { $lt: 25 } }, { name: "Alice" } ] })
  3. 非 ($not)

    sh 复制代码
    db.collection.find({ key: { $not: { condition } } })

    示例:

    sh 复制代码
    db.users.find({ age: { $not: { $gt: 25 } } })

嵌套文档查询

  1. 查询嵌套文档中的字段

    sh 复制代码
    db.collection.find({ "nested.key": value })

    示例:

    sh 复制代码
    db.users.find({ "address.city": "New York" })

数组操作符

  1. 数组中包含某个值 ($in)

    sh 复制代码
    db.collection.find({ key: { $in: [ value1, value2 ] } })

    示例:

    sh 复制代码
    db.users.find({ favoriteColors: { $in: [ "red", "blue" ] } })
  2. 数组中不包含某个值 ($nin)

    sh 复制代码
    db.collection.find({ key: { $nin: [ value1, value2 ] } })

    示例:

    sh 复制代码
    db.users.find({ favoriteColors: { $nin: [ "red", "blue" ] } })
  3. 数组中包含所有值 ($all)

    sh 复制代码
    db.collection.find({ key: { $all: [ value1, value2 ] } })

    示例:

    sh 复制代码
    db.users.find({ favoriteColors: { $all: [ "red", "blue" ] } })

示例查询

假设你有一个名为 mydatabase 的数据库和一个名为 users 的集合,集合中的文档结构如下:

json 复制代码
{
  "name": "Alice",
  "age": 25,
  "address": {
    "city": "New York",
    "zip": "10001"
  },
  "favoriteColors": ["red", "blue"]
}

你可以进行以下查询:

  1. 查询所有用户

    sh 复制代码
    db.users.find().pretty()
  2. 查询年龄大于 25 的用户

    sh 复制代码
    db.users.find({ age: { $gt: 25 } })
  3. 查询住在 New York 的用户

    sh 复制代码
    db.users.find({ "address.city": "New York" })
  4. 查询喜欢红色或蓝色的用户

    sh 复制代码
    db.users.find({ favoriteColors: { $in: [ "red", "blue" ] } })

这些示例展示了如何在 MongoDB 中执行各种查询操作。根据需要,可以调整和扩展查询条件。

相关推荐
凉栀お_10 分钟前
MySQL相关知识查询表中内容(第二次作业)
数据库·mysql
ss27338 分钟前
手写Spring第7弹:Spring IoC容器深度解析:XML配置的完整指南
java·前端·数据库
PFinal社区_南丞1 小时前
PostgreSQL-10个鲜为人知的强大功能
数据库·后端
misty youth1 小时前
配置openguass 教程(自存)
数据库·ubuntu·华为·openguass
瑞士卷@2 小时前
MyBatis入门到精通(Mybatis学习笔记)
java·数据库·后端·mybatis
白云偷星子2 小时前
MySQL笔记13
数据库·笔记·mysql
施嘉伟2 小时前
静默安装金仓数据库,到底有多简单?
数据库
Tapdata2 小时前
实时物化视图的新路径:从传统 Join 到跨源实时查询
数据库
optimistic_chen3 小时前
【Java EE进阶 --- SpringBoot】Mybatis - plus 操作数据库
数据库·spring boot·笔记·java-ee·mybatis·mybatis-plus
FJW0208143 小时前
关系型数据库大王Mysql——DDL语句操作示例
数据库·mysql