目录:

  • 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. Nginx模块及配置虚拟主机

    1.Nginx的2组主要的模块 (1)core modules (必需,核心模块) 包括:Main.Events (2)Standard HTTP modules(虽然不是必需,但是缺省都会安装,不建 ...

  2. C# TreeView模糊查找节点

    List<TreeNode> listSearchTreeNodes; private void btn_Search_Click(object sender, EventArgs e) ...

  3. git常用情景和基础命令

    git常用情景和基础命令 将项目克隆到本地 --xxx是git的地址 git clone xxxx 或者初始化git(github提供滴) --新建一个readme.md文件 echo "# ...

  4. Linux逻辑卷的创建

    什么是LVM? LVM(逻辑卷管理器):是Linux环境下对磁盘分区进行管理的一种机制.主要作用是动态分配磁盘分区及调整磁盘分区大小,并且可以让多个分区或者物理硬盘作为一个逻辑卷(相当于一个逻辑硬盘) ...

  5. 一些webpack常见编译报错的解决方案

    重新安装依赖可以解决80%的webpack编译报错问题. rm -rf node_modules rm package-lock.json npm cache clear --force npm in ...

  6. IDEA新建Spring配置文件的方法

    IDEA创建Spring Config 选择项目文件右键 输入文件名称即可 applicationContext.xml

  7. Linux系统学习 二十二、SAMBA服务—Samba基本使用—share权限访问、客户端的使用

    share权限访问 配置文件修改 [global]全局设置 workgroup=MYGROUP server string=Samba Server Lamp log file=/var/log/sa ...

  8. Office2019新增哪些功能

    上一篇文章我们知道了office为什么没有2017/2018版本,那个是因为微软office是时隔三年一更新的软件,这不office2019就出来了.一款软件,只有不断的完善自身功能,进行不断的更新, ...

  9. APScheduler学习

    说明 APScheduler是一个 Python 定时任务框架,使用起来十分方便.提供了基于日期.固定时间间隔以及 crontab 类型的任务,并且可以持久化任务.并以 daemon 方式运行应用. ...

  10. verilog常见错误列表

    Error/Warning 来源:https://hdlbits.01xz.net/wiki/ 题目: 1.Quartus Warning 10235: Warning (): Verilog HDL ...