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 中执行各种查询操作。根据需要,可以调整和扩展查询条件。

相关推荐
GottdesKrieges26 分钟前
obd运维OceanBase数据库的常见场景
运维·数据库·oceanbase
慢慢沉2 小时前
Lua(数据库访问)
开发语言·数据库·lua
武子康6 小时前
Java-82 深入浅出 MySQL 内部架构:服务层、存储引擎与文件系统全覆盖
java·开发语言·数据库·学习·mysql·spring·微服务
vdoi8 小时前
【Mysql】 Mysql zip解压版 Win11 安装备忘
数据库·mysql
TDengine (老段)9 小时前
TDengine 转化类函数 TO_CHAR 用户手册
大数据·数据库·物联网·时序数据库·tdengine·涛思数据
程序员编程指南9 小时前
Qt 与 SQLite 嵌入式数据库开发
c语言·数据库·c++·qt
fht19 小时前
SQLite
数据库·sqlite
float_六七10 小时前
MySQL索引背后的B+树奥秘
数据库·b树·mysql
~央千澈~10 小时前
MongoDB数据库详解-针对大型分布式项目采用的原因以及基础原理和发展-卓伊凡|贝贝|莉莉
数据库·mongodb
Java初学者小白11 小时前
秋招Day18 - MyBatis - 基础
java·数据库·mybatis