MongoDB 查询文档(五)

吃苹果的上帝 2018-01-31 14:45:26 ⋅ 759 阅读

第一部分 前期准备

1.1 插入测试数据

db.test1.insertMany([
    {"name": "zhangsan", "age": 19, "score": [90, 80]},
    {"name": "lisi", "age": 29, "score": [40, 60]},
    {"name": "xiaoming", "age": 18, "score": [20, 40]},
    {"name": "xiaohong"}
])

第二部分 Find

2.1 Find查询数据的语法格式如下:

> db.collection.find(query, projection)
1. query[可选]: 主要是一些筛选条件, 文档类型数据;
2. projection[可选]: 返回的限制字段, 文档类型.

2.2 find 筛选全部数据

第一种, 罗列全部数据
> db.test1.find()
{ "_id" : ObjectId("58c8dc54ef9b994487420f29"), "name" : "zhangsan", "age" : 19, "score" : [ 90, 80 ] }
{ "_id" : ObjectId("58c8dc54ef9b994487420f2a"), "name" : "lisi", "age" : 29, "score" : [ 40, 60 ] }
{ "_id" : ObjectId("58c8dc54ef9b994487420f2b"), "name" : "xiaoming", "age" : 18, "score" : [ 20, 40 ] }
第二种 筛选某一条数据
> db.test1.find({"name": "xiaoming"})
{ "_id" : ObjectId("58c8dc54ef9b994487420f2b"), "name" : "xiaoming", "age" : 18, "score" : [ 20, 40 ] }
第三种 指定返回字段

1或true代表显示, 0或false代表不显示

> db.test1.find({"name": "xiaoming"}, {"age": 1, "name": 1})
{ "_id" : ObjectId("58c8dc54ef9b994487420f2b"), "name" : "xiaoming", "age" : 18 }

第三部分 查询选择器

3.1 比较选择器

[eq: equal, g: greater, l: less, t: than, n: not, in: in]
1. $eq  :    对比值等于指定值
2. $gt  :    ...大于...
3. $gte:       ...大于等于...
4. $lt:     ...大于...
5. $lte:    ...小于等于...
6. $ne  :    对比值 全部不等于 指定值
7. $in:        指定数组包含对比值
8. $nin:       指定数组不包含对比值
3.1.1 $eq

配置键值对[两种写法]

#eq> db.test1.find({"age": {"$eq": 18}})
{ "_id" : ObjectId("58c8dc54ef9b994487420f2b"), "name" : "xiaoming", "age" : 18, "score" : [ 20, 40 ] }#省略, 结果一样> db.test1.find({"age": 18})

匹配数组元素

> db.test1.find({"score": {"$eq": 80}})
{ "_id" : ObjectId("58c8dc54ef9b994487420f29"), "name" : "zhangsan", "age" : 19, "score" : [ 90, 80 ], "qty" : 10 }#省略, 结果一样> db.test1.find({"score": 80})

匹配数组

#无结果, 因为在此是相当于 db.test1.find({"score": {"$eq": [20, 30]}})> db.test1.find({"score": [20, 30]})
> db.test1.find({"score": [20, 40]})
{ "_id" : ObjectId("58c8dc54ef9b994487420f2b"), "name" : "xiaoming", "age" : 18, "score" : [ 20, 40 ] }
3.1.2 $gt 除了数字可以比较之外, 不能忽略BJSON其他类型都可以比较

数字

> db.test1.find({"age": {"$gt": 20}})
{ "_id" : ObjectId("58c8dc54ef9b994487420f2a"), "name" : "lisi", "age" : 29, "score" : [ 40, 60 ] }

字符串同样可以比较更多参考BSON Types

> db.test1.find({"name": {"$gt": "lisi"}})
{ "_id" : ObjectId("58c8dc54ef9b994487420f29"), "name" : "zhangsan", "age" : 19, "score" : [ 90, 80 ], "qty" : 10 }
{ "_id" : ObjectId("58c8dc54ef9b994487420f2b"), "name" : "xiaoming", "age" : 18, "score" : [ 20, 40 ] }
3.1.3 $gte
> db.test1.find({"age": {"$gte": 19}})
{ "_id" : ObjectId("58c8dc54ef9b994487420f29"), "name" : "zhangsan", "age" : 19, "score" : [ 90, 80 ], "qty" : 10 }
{ "_id" : ObjectId("58c8dc54ef9b994487420f2a"), "name" : "lisi", "age" : 29, "score" : [ 40, 60 ] }
3.1.4. $lt
> db.test1.find({"age": {"$lt": 19}})
{ "_id" : ObjectId("58c8dc54ef9b994487420f2b"), "name" : "xiaoming", "age" : 18, "score" : [ 20, 40 ] }
3.1.5. $lte
> db.test1.find({"age": {"$lte": 19}})
{ "_id" : ObjectId("58c8dc54ef9b994487420f29"), "name" : "zhangsan", "age" : 19, "score" : [ 90, 80 ], "qty" : 10 }
{ "_id" : ObjectId("58c8dc54ef9b994487420f2b"), "name" : "xiaoming", "age" : 18, "score" : [ 20, 40 ] }
3.1.6 $ne 不等于指定值
> db.test1.find({"name": {"$ne": "xiaoming"}})
{ "_id" : ObjectId("58c8dc54ef9b994487420f29"), "name" : "zhangsan", "age" : 19, "score" : [ 90, 80 ], "qty" : 10 }
{ "_id" : ObjectId("58c8dc54ef9b994487420f2a"), "name" : "lisi", "age" : 29, "score" : [ 40, 60 ] }
3.1.7 $in 符合指定数组内的任一个即满足
> db.test1.find({"score": {"$in": [90, 100]}})
{ "_id" : ObjectId("58c8dc54ef9b994487420f29"), "name" : "zhangsan", "age" : 19, "score" : [ 90, 80 ], "qty" : 10 }
> db.test1.find({"score": {"$in": [89, 100]}})
3.1.8 $nin 指定数据都不属于指定数组的子集
#三条数据全部不存在89 100, 就输出> db.test1.find({"score": {"$nin": [89, 100]}})
{ "_id" : ObjectId("58c8dc54ef9b994487420f29"), "name" : "zhangsan", "age" : 19, "score" : [ 90, 80 ], "qty" : 10 }
{ "_id" : ObjectId("58c8dc54ef9b994487420f2a"), "name" : "lisi", "age" : 29, "score" : [ 40, 60 ] }
{ "_id" : ObjectId("58c8dc54ef9b994487420f2b"), "name" : "xiaoming", "age" : 18, "score" : [ 20, 40 ] }

3.2 逻辑选择器

1. $or: 在一个数组上(二个或更多)执行逻辑||, 满足至少一个, 就算是满足2. $and: 逻辑 &&3. $not: 指定字段不匹配操作表达式, 或不存在该字段4. $nor:    $not 与 $or结合体
3.2.1 $or

语法

{ $or: [ { <expression1> }, { <expression2> }, ... , { <expressionN> } ] }
> db.test1.find({"$or": [{"age": 18}, {"name": "zhangsan"}]})#满足{"name": "zhangsan"}, 输出{ "_id" : ObjectId("58c8dc54ef9b994487420f29"), "name" : "zhangsan", "age" : 19, "score" : [ 90, 80 ], "qty" : 10 }#满足{"age": 18}, 输出{ "_id" : ObjectId("58c8dc54ef9b994487420f2b"), "name" : "xiaoming", "age" : 18, "score" : [ 20, 40 ] }

$or$in的异同

3.2.2 $and
{ $and: [ { <expression1> }, { <expression2> } , ... , { <expressionN> } ] }
#没有满足的> db.test1.find({"$and": [{"age": 18}, {"name": "zhangsan"}]})#同时满足全部条件: 1.{"age": 18} 2.{"name": "xiaoming"}> db.test1.find({"$and": [{"age": 18}, {"name": "xiaoming"}]})
{ "_id" : ObjectId("58c8dc54ef9b994487420f2b"), "name" : "xiaoming", "age" : 18, "score" : [ 20, 40 ] }
3.2.3 $not
{ field: { $not: { <operator-expression> } } }

执行$not

> db.test1.find({"age": {"$not":{"$gt": 19}}})

{ "_id" : ObjectId("58c8dc54ef9b994487420f29"), "name" : "zhangsan", "age" : 19, "score" : [ 90, 80 ], "qty" : 10 }
{ "_id" : ObjectId("58c8dc54ef9b994487420f2b"), "name" : "xiaoming", "age" : 18, "score" : [ 20, 40 ] }
{ "_id" : ObjectId("58c9e4b80c4d4cf6f4563b26"), "name" : "xiaohong" }

{"age": {"$not":{"$gt": 19}}}筛选的数据:

1. 小于等于19;
2. 不存在age字段
3.2.4. $nor
{ $nor: [ { <expression1> }, { <expression2> }, ...  { <expressionN> } ] }

备选数据

> db.test1.find().pretty()
{    "_id" : ObjectId("58c8dc54ef9b994487420f29"),    "name" : "zhangsan",    "age" : 19,    "score" : [
        90,
        80
    ],    "qty" : 10
}
{    "_id" : ObjectId("58c8dc54ef9b994487420f2a"),    "name" : "lisi",    "age" : 29,    "score" : [
        40,
        60
    ]
}
{    "_id" : ObjectId("58c8dc54ef9b994487420f2b"),    "name" : "xiaoming",    "age" : 18,    "score" : [
        20,
        40
    ]
}
{ "_id" : ObjectId("58c9e4b80c4d4cf6f4563b26"), "name" : "xiaohong" }

执行$nor

> db.test1.find({"$nor": [{"age": {"$gt": 20}}, {"qty": 10}]})
{ "_id" : ObjectId("58c8dc54ef9b994487420f2b"), "name" : "xiaoming", "age" : 18, "score" : [ 20, 40 ] }
{ "_id" : ObjectId("58c9e4b80c4d4cf6f4563b26"), "name" : "xiaohong" }

分解上述执行过程

1. age小于等于20, qty不等于10;
2. age小于等于20, qty字段不存在;
3. age字段不存在, qty不等于10;
4. age字段不存在, qty字段不存在;
Tip
1. db.collection.count(): 集合内对象个数;
2. db.collection.dataSize(): 集合所占大小;

更多精彩内容请关注“IT实战联盟”公众号哦~~~



全部评论: 0

    我有话说:

    MongoDB 更新/删除文档(四)

    第一部分 更新文档 文档存入数据库之后,就可以采用Update来修改它的内容, db.collection.update( #查询条件   <query>, #修改器

    MongoDB系列---数据类型/插入文档(三)

    第一部分 BJSON 与 JSON MongoDB文档与JavaScript中的对象很相似,JavaScript中的数据交互格式是JSON格式. JSON的数据格式: 1. null;2. 布尔

    MongoDB 更新/删除文档(四)

    更新文档文档存入数据库之后,就可以采用Update来修改它的内容,db.collection.up

    MongoDB实战篇:高级查询----$elemMatch与aggregate

    基本的Find查询将在其他章节示例,本文主要针对于遇到的问题与解决的方法做个记录,希望可以减少遇到这类问题的

    MongoDB系列之----概述(一)

    MongoDB是由C++语言编写的,是一个基于分布式文件存储的开源数据库系统。

    MongoDB 数据库的基本操作(二)

    MongoDB 是一个基于分布式文件存储的数据库。由 C++ 语言编写。旨在为 WEB 应用提供可扩展的高性能数据存储解决方案。

    MongoDB更新(

    如果数据库中尚未有数据, 准备测试数据db.test1.insertMany([    {"name": "zhangsan", "age": 19, "score": [90, 80]},    {"na...

    MongoHelper 0.2.5 发布,Spring-Data-MongoDB 增强工具包

    工具包简化 CRUD 操作,并且提供了类 jpa 的数据库操作。

    MongoDB实战篇:数据库备份与恢复/导出与导入

    mongodump命令可以通过参数指定导出的数据量级转存的服务器......

    MongoDB 4.4.5 发布

    MongoDB 是一种面向文档的数据库管理系统,用 C++ 等语言撰写而成,以解决应用程序开发社区中的大量现实问题。MongoDBMongoDB Inc. 于 2007 年 10 月开发

    Syncthing 1.11.0 和 1.11.1 发布,连续文件同步工具

    Syncthing 是一个免费开源的工具,它能在你的各个网络计算机间同步文件/文件夹,它的同步数据是直接从一个系统中直接传输到另一个系统的,并且它是安全且私密的。 Syncthing 1

    Mongoose 5.12.5 发布,MongoDB 异步对象模型工具

    Mongoose 是设计用于异步环境的 MongoDB 对象模型工具。Mongoose 支持 promises 和 callbacks。Mongoose 5.12.5 正式发布,本次更新内容如下

    Node模块之Events模块()

    Node模块之Events模块()

    「开源资讯」Atom 1.52.0 和1.53.0-beta0发布,跨平台文本编辑器

    Atom 同时发布了 1.52.0 和 1.53.0-beta0 版本。Atom 是 GitHub 专门为程序员推出的一个跨平台文本编辑器。具有简洁和直观的图形用户界面,并有很多有趣的特点:支持

    关于MySQL 通用查询日志和慢查询日志分析

    MySQL中的日志包括:错误日志、二进制日志、通用查询日志、慢查询日志等等。这里主要介绍下比较常用的两个功能:通用查询日志和慢查询日志。

    您应该避免的个简单的数据库设计错误

    Anith 在他非常成功的文章 Facts and Fallacies about First Normal Form 之后,对个常见的数据库设计错误进行了引人入胜的讨论,尽管使用它们的不幸后果

    移动H5前端大性能优化方案(实战篇)

    移动H5前端大性能优化方案(实战篇)