一、填空题
1.MongoDB是一个_面向文档的__、跨平台的数据库。
2._mongod.exe__程序用于启动MongoDB服务器。
3.MongoDB服务的端口号是__27017____。
4.__聚合管道____是使用不同的管道阶段操作器进行不同聚合操作。
5.MongoDB提供__Map-Reduce__操作来进行聚合操作。
二、判断题
1.针对不同的操作系统平台,MongoDB的部署均相同。 ( × )
2.MongoDB中管道操作符的类型单一。 ( × )
3.Map-Reduce操作有两个阶段,即Map和Reduce阶段。 ( √ )
4.默认情况下,MongoDB服务启动运行时是启用用户访问权限控制的。 ( × )
5.Robo 3T是一个跨平台的MongoDB GUI客户端管理工具。 ( √ )
三、选择题
1.下列命令中,哪个可以用于创建MongoDB数据库?( A)
A.create
B.show
C.use
D.db
2.下列选项中,哪个不属于管道操作符?(D )
A.$group
B.$limit
C.$match
D.$and
3.下列说法中,关于MongoDB索引说法正确的是?(BD )
A.索引存储着集合中全部的文档
B.索引项的排序支持有效的等值匹配和基于范围的查询操作
C.索引分为单字段索引和复合索引两种
D.索引是一种特殊的数据结构,即采用B-Tree数据结构
四、简答题
简述MongoDB的索引六种类型。
1、单字段索引
MongoDB支持在文档的单个字段上创建用户定义的升序、降序索引,因此被称为单字段索引。默认情况下,MongoDB中所有集合在”_id”字段上都有一个索引,用户也可以根据自己的需求添加额外索引来支持重要的查询和操作。MongoDB可以从任意方向遍历索引,对于单个字段索引和排序操作来说,索引项的排序顺序并不重要。
2、复合索引
复合索引就是包含多个字段的索引,一个复合索引最多可以包含31个字段,若某字段属于哈希索引,复合索引就不能包含该字段。复合索引是由{userid:1,score:-1}组成的,因此复合索引首先按字段userid进行升序排序,然后在每个字段userid的值内,按照score降序排序。
3、多键索引
若文档中的字段为数组类型,则每个字段都是数组中的一个元素,MongoDB将会为数组中每个元素创建索引,因此被称为多键索引。多键索引允许通过匹配数组的一个或多个元素来查询包含该数组的文档。如果索引字段包含数组值,则MongoDB会自动确定是否创建多键索引,而无需显式的指定创建多键索引。
4、地理空间索引
为了支持对地理空间坐标数据的有效查询,MongoDB提供了两种特殊的索引,即返回结果时使用平面几何的二维索引(2d索引)和返回结果时使用球面几何的二维球面索引(2dsphere索引)。其中,2d索引支持在欧几里德平面上的计算,也支持计算球面上的距离;2dsphere索引支持球面上几何计算的查询,包含查询(在一个指定多边形内的位置进行查询)、 交集查询(查询指定几何相交的位置)和临近查询(如查询离另一个点最近的点)。我们可以通过将2d索引和2dsphere索引进行相结合,从而进行高效的地理空间查询。
5、文本索引
MongoDB提供了一种文本索引类型,支持在集合中搜索字符串内容,即进行文本检索查询。文本索引不存储特定语言的停止词,例如“the”、“a”以及“or”等词,而是将集合中的词作为词干,只存储根词。为了执行文本检索查询,则集合上必须有一个text索引。一个集合只能拥有一个文本检索索引,但是这个索引可以覆盖多个字段。
6、哈希索引
为了支持基于哈希分片键进行分片,MongoDB提供了哈希索引类型。哈希索引是使用哈希函数来计算索引字段的哈希值,若是该索引字段的哈希值在哈希索引的范围内,则分布的更加随机。需要注意的是,哈希索引只支持等值匹配,不支持基于范围的查询。
五、操作题
1. 通过MongoDB的Java API编程,实现以下的操作:
(1)创建集合。
(2)查看集合。
(3)在集合中插入文档。
(4)查看集合中的文档。
(5)删除集合中的指定文档。
2. 通过MongoDB GUI客户端管理工具,实现以下操作:
(1)创建、删除数据库。
(2)创建、查看、删除集合。
创建集合:
查看集合:
删除集合:
(3)插入、查看、更新文档。
插入文档:
查看文档:
更新文档: