目录:

  • MongoDB数据类型
  • MongoDB新增语法
  • MongoDB查询语法
  • MongoDB查询选择器
  • MongoDB关联查询

MongoDB数据类型:

MongoDB新增语法:

语法:db.collectionName.insert(document)

示例

1、db.local.insert({name:'thinking in java', price:88.08})

2、或者是先定义变量

var data = {name:'jdr', age:18}

db.local.insert(data)

MongoDB查询语法:

db.collectionName.find(query, projection)

参数说明

1、query:可选;可使用查询操作符指定查询条件。

2、projection:可选;可指定返回的键,若不指定则返回所有的键(1=显示,0=不展示)

示例

1、查询所有:db.local.find()

2、查询指定条件:db.local.find({name: 'zd'})

3、如果想要返回的数据易读的话可加上pretty():db.local.find({name: 'zd'}).pretty()

4、指定返回name:db.local.find({},{name:1})

5、指定不返回name:db.local.find({},{name:0})

MongoDB查询选择器:

1、范围选择器、布尔选择器、正则选择器:

2、排序选择器:1=升序,-1=降序

db.local.find().sort({name:1, age:-1})

3、跳过和限制选择器,跳过前面n条数据,限制和mysql中limit效果一致

db.local.find().skip(1).limit(2)

4、过滤重复字段选择器,和mysql中distinct一致

db.local.distinct()

5、 数组选择器

)单元素查询:db.local.find({'favorites.movies':'凹凸曼'})

)多元素查询:db.local.find({'favorites.movies':{'$all':['阿凡达', '泰坦尼克号']}})

)精准查找:db.local.find({'favorites.movies':['凹凸曼', '美队2', '喜羊羊与灰太狼']})

)索引查询(查找数组中第一个钢铁侠的喜欢电影):db.local.find({'favorites.movies.0':'钢铁侠'})

)数组子集:db.local.find({}, {'favorites.movies':{'$slice':[3,3], '_id':1}})

'$slice':[3,3]:跳过前3条数据并取3条数据

6、对象数组选择器

)单元素查询:db.local.find({'citys':{'code':0001, 'addr':'上海'}})

)多元素查询:db.local.find({'comments':{'$elemMatch':{'movies':'倩女幽魂', 'content':'好看!'}}})

demo:https://github.com/mrjdrs/mongodb-demo/tree/master/mongo-selector

MongoDB关联查询:

因mongo单个文档大小不能超过16M,但因特殊的业务场景我们又不得不这样存储,为了解决这一问题mongo提供了DBRef。

DBRef语法:

1、$ref:引用文档所在聚合名称。

2、$id:所在集合的id值。

3、$db:可选;集合所在库的实例名。

示例

db.collectionName.insert({"name":"zd", "userId":
{"$ref":"users", "$id":ObjectId("objectId value"), "$db":"dbName"}
})
db.collectionName.insert({"name":"zd", "userId":
[
{"$ref":"users", "$id":ObjectId("objectId value"), "$db":"dbName"},
{"$ref":"users", "$id":ObjectId("objectId value"), "$db":"dbName"},
]
}) db.collectionName.findOne({"name":"zd"}).userId.fetch()
db.collectionName.findOne({"name":"zd"}).userId[0].fetch()

MongoDB学习笔记(二、MongoDB查询)的更多相关文章

  1. Mongodb学习笔记二(Mongodb基本命令)

    第二章 基本命令 一.Mongodb命令 说明:Mongodb命令是区分大小写的,使用的命名规则是驼峰命名法. 对于database和collection无需主动创建,在插入数据时,如果databas ...

  2. MongoDB学习笔记二- Mongoose

    MongoDB学习笔记二 Mongoose Mongoose 简介 之前我们都是通过shell来完成对数据库的各种操作, 在开发中大部分时候我们都需要通过程序来完成对数据库的操作 而Mongoose就 ...

  3. Mongodb学习笔记一(Mongodb环境配置)

    Mongodb学习 说明: MongoDB由databases组成,database由collections组成,collection由documents组成,document由fileds组成.Mo ...

  4. MongoDB学习笔记一(MongoDB介绍 + 基本指令 + 查询语句)

    什么是MongoDB MongoDB 是由C++语言编写的,是一个基于分布式文件存储的开源数据库系统. 在高负载的情况下,添加更多的节点,可以保证服务器性能. MongoDB 旨在为WEB应用提供可扩 ...

  5. MongoDB学习笔记二—Shell操作

    数据类型 MongoDB在保留JSON基本键/值对特性的基础上,添加了其他一些数据类型. null null用于表示空值或者不存在的字段:{“x”:null} 布尔型 布尔类型有两个值true和fal ...

  6. MongoDB学习笔记三:查询

    MongoDB中使用find来进行查询.查询就是返回一个集合中文档的子集,子集合的范围从0个文档到整个集合.find的第一个参数决定了要返回哪些文档,其形式也是一个文档,说明要执行的查询细节.空的查询 ...

  7. MongoDB学习笔记(一) MongoDB介绍及安装(摘)

    MongoDB是一个高性能,开源,无模式的文档型数据库,是当前NoSql数据库中比较热门的一种.它在许多场景下可用于替代传统的关系型数据库或键/值存储方式.Mongo使用C++开发.Mongo的官方网 ...

  8. MongoDb 学习笔记(一) --- MongoDb 数据库介绍、安装、使用

    1.数据库和文件的主要区别 . 数据库有数据库表.行和列的概念,让我们存储操作数据更方便 . 数据库提供了非常方便的接口,可以让 nodejs.php java .net 很方便的实现增加修改删除功能 ...

  9. MongoDB学习笔记~索引提高查询效率

    回到目录 索引这个东西大家不会陌生,只要接触到稍微大一点的数据,都会用到这东西,它可以提升查询的速度,相当代价就是占用了更多的存储空间,这也是正常的,符合“能量守恒定理”,哈哈!今天说的是MongoD ...

  10. MongoDB学习笔记二:创建、更新及删除文档

    插入并保存文档 对目标集使用insert方法插入一个文档: > db.foo.insert({"bar" : "baz"}) 这个操作会给文档增加一个&q ...

随机推荐

  1. Nacos Cluster Building

    原文链接:https://www.javaspring.net/nacos/nacos-cluster-building Continue to talk about the Nacos build ...

  2. EFCore某张表中获取某几个字段

    目录 EFCore某张表中获取某几个字段 1.背景 2.法一:linq 2.1 使用Select方法 2.2 使用ForEach方法 2.3 其他参考代码 3.法二:IQueryble 3.1 参考例 ...

  3. How to: Use the Entity Framework Code First in XAF 如何:在 XAF 中使用EF CodeFirst

    This topic demonstrates how to create a simple XAF application with a business model in a DbContext ...

  4. 基于SpringBoot前后端分离的点餐系统

    基于SpringBoot前后端分离的点餐系统 开发环境:主要采用Spring boot框架和小程序开发 项目简介:点餐系统,分成卖家端和买家端.买家端使用微信小程序开发,实现扫码点餐.浏览菜单.下单. ...

  5. Angular + Leaflet 实现房源数据可视化(附github源码)

    这是什么?租房信息展示平台 宏观的租房数据可视化微观的房源信息展示多条件搜索等等 链接地图搜租房​ 来龙去脉 受 @李国宝 的地图搜租房启发,利用其提供的开放API,配合自己在前端和地理信息系统方面的 ...

  6. golang.org 安装脚本

    #!/usr/bin/env bash cd $GOPATH; #创建 $GOPATH/src/golang.org/x 目录 mkdir -p $GOPATH/src/golang.org/x; e ...

  7. JavaScript banner轮播 左右切换 圆点点击切换

    1.效果如下图: 2.源码如下: <!DOCTYPE html> <html lang="en"> <head> <meta charse ...

  8. http服务需要pycurl模块这样去监控服务

    最近运维还是比较空闲,写篇自己的心得体会.做过运维的应该都做过http服务了.像一些电子商城,或者是一些互联网公司,web的服务之类是至关重要的,近期看了刘天斯大哥的书觉得自己运维平台应该也可以这样去 ...

  9. avd manger创建的虚拟机启动不起来,或者启动起来后黑屏

    最近鼓捣安卓虚拟机,整的都差点重装系统,刚开始下载了genymotion_vbox,装完以后要在vbox中导入一个虚拟机,结果我导入完,虚拟机怎么也启动不了,然后各种找办法无果,最后重启电脑发现电脑也 ...

  10. 在浏览器地址栏输入www.baidu.com到打开百度首页这期间到底发生了什么?

    刚才无意间看到这么一个面试题,觉得有点意思,我想从五层网络模型的角度说说我的看法. 1.首先通过DNS域名系统向域名服务器发送域名解析请求来得到百度的IP地址39.156.69.79:2.系统通过AR ...