MongoDB面试宝典【刷题系列】

news/2025/2/26 6:53:58

文章目录

    • 1、MySQL与MongoDB之间最基本的差别是什么?
    • 2、MongoDB成为最好NoSQL数据库的原因是什么?
    • 3、分析器在MongoDB中的作用是什么?
    • 4、如果用户移除对象的属性,该属性是否从存储层中删除?
    • 5、更新操作立刻fsync到磁盘?
    • 6、什么是master或primary?
    • 7、 数据在什么时候才会扩展到多个分片(shard)里?
    • 8、分片(sharding)和复制(replication)是怎样工作的?
    • 9、如果块移动操作(moveChunk)失败了,需要手动清除部分转移的文档吗?
    • 10、如果一个分片(Shard)停止或很慢的时候,发起一个查询会怎样?
    • 11、如何理解MongoDB中的GridFS机制,MongoDB为何使用GridFS来存储文件?
    • 12、MongoDB支持存储过程吗?如果支持的话,怎么用?
    • 13、当更新一个正在被迁移的块(Chunk)上的文档时会发生什么?


在这里插入图片描述

1、MySQL与MongoDB之间最基本的差别是什么?

答:MySQLMongoDB 两者都是免费开源的数据库。MySQL和MongoDB有许多基本差别包括数据的表示( data representation ),查询,关系,事务,schema 的设计和定义,标准化( normalization ),速度和性能。

通过比较 MySQLMongoDB ,实际上我们是在比较关系型和非关系型数据库,即数据存储结构不同。详细阅读

2、MongoDB成为最好NoSQL数据库的原因是什么?

答:以下特点使得 MongoDB 成为最好的 NoSQL 数据库

  • 面向文件的
  • 高性能
  • 高可用性
  • 易扩展性
  • 丰富的查询语言

3、分析器在MongoDB中的作用是什么?

答:MongoDB 中包括了一个可以显示数据库中每个操作性能特点的数据库分析器。通过这个分析器你可以找到比预期慢的查询(或写操作);利用这一信息,比如,可以确定是否需要添加索引。

4、如果用户移除对象的属性,该属性是否从存储层中删除?

答:是的,用户移除属性然后对象会重新保存( re-save() )。

5、更新操作立刻fsync到磁盘?

答:不会,磁盘写操作默认是延迟执行的。写操作可能在两三秒(默认在 60 秒内)后到达磁盘。例如,如果一秒内数据库收到一千个对一个对象递增的操作,仅刷新磁盘一次。

6、什么是master或primary?

答:它是当前备份集群( replica set )中负责处理所有写入操作的主要节点/成员。在一个备份集群中,当失效备援( failover )事件发生时,一个另外的成员会变成 primary

7、 数据在什么时候才会扩展到多个分片(shard)里?

答:MongoDB 分片是基于区域( range )的。所以一个集合( collection )中的所有的对象都被存放到一个块( chunk )中。只有当存在多余一个块的时候,才会有多个分片获取数据的选项。现在,每个默认块的大小是 64Mb ,所以你需要至少 64Mb 空间才可以实施一个迁移。

8、分片(sharding)和复制(replication)是怎样工作的?

答:每一个分片( shard )是一个分区数据的逻辑集合。分片可能由单一服务器或者集群组成,我们推荐为每一个分片( shard )使用集群。

9、如果块移动操作(moveChunk)失败了,需要手动清除部分转移的文档吗?

答:不需要,移动操作是一致( consistent )并且是确定性的( deterministic );一次失败后,移动操作会不断重试;当完成后,数据只会出现在新的分片里( shard )。

10、如果一个分片(Shard)停止或很慢的时候,发起一个查询会怎样?

答:如果一个分片停止了,除非查询设置了 “Partial” 选项,否则查询会返回一个错误。如果一个分片响应很慢,MongoDB会等待它的响应。

11、如何理解MongoDB中的GridFS机制,MongoDB为何使用GridFS来存储文件?

答:GridFS 是一种将大型文件存储在MongoDB中的文件规范。使用 GridFS 可以将大文件分隔成多个小文档存放,这样我们能够有效的保存大文档,而且解决了BSON 对象有限制的问题。

12、MongoDB支持存储过程吗?如果支持的话,怎么用?

答:MongoDB支持存储过程,它是 javascript 写的,保存在 db.system.js 表中。

13、当更新一个正在被迁移的块(Chunk)上的文档时会发生什么?

答:更新操作会立即发生在旧的块(Chunk)上,然后更改才会在所有权转移前复制到新的分片上。


http://www.niftyadmin.cn/n/5868257.html

相关文章

利用go-migrate实现MySQL和ClickHouse的数据库迁移

1. 背景 在使用gorm时 , 尽管已经有了自动建表和钩子函数 . 但是在面临希望了解到数据库的变更 , 和插入一些系统字段时 , 以及最关键的数据库迁移的工作 . gorm显得稍微有点不便 . 在了解到migrate这项技术后 , 就使用go-migrate开发了一个可以迁移MySQL和ClickHouse数据库的…

Sqlserver安全篇之_隐藏实例功能和禁用SQL Server Browser服务

总结: 1、隐藏实例功能和禁用SQL Server Browser服务的功能一样,对应非默认实例(且这个默认实例是1433端口)的情况下,都是需要在连接字符串中提供端口号才能连接到实例 2、隐藏实例功能后,就算开启了SQL Server Browser服务&#…

JVM生产环境问题定位与解决实战(三):揭秘Java飞行记录器(JFR)的强大功能

提到飞行记录器,或许你的脑海中并未立刻浮现出清晰的画面,但一说起“黑匣子”,想必大多数人都能恍然大悟,知晓其重要性及用途。在航空领域,黑匣子作为不可或缺的设备,默默记录着飞行过程中的每一项关键数据…

1.1部署es:9200

安装es:root用户: 1.布署java环境 - 所有节点 wget https://d6.injdk.cn/oraclejdk/8/jdk-8u341-linux-x64.rpm yum localinstall jdk-8u341-linux-x64.rpm -y java -version 2.下载安装elasticsearch - 所有节点 wget ftp://10.3.148.254/Note/Elk/…

Java进阶学习笔记7——权限修饰符

什么是权限修饰符? 就是用来限制类中的成员(成员变量、成员方法、构造器、代码块…)能够被访问的范围。 protected使用的比较少,但是程序员还是要阅读代码,看官方文档是怎么写的,都会接触到protected修饰…

Linux 之 Centos 安装Consul

sudo yum install -y yum-utils sudo yum-config-manager --add-repo https://rpm.releases.hashicorp.com/RHEL/hashicorp.repo sudo yum -y install consul他有两种运行模式server和client。每个数据中心官方建议需要3或5个server节点以保证数据安全,同时保证serv…

Git -版本管理工具 -常用API整理

文章目录 前言常用API1. 设置本地的名称2. 创建仓库3. 克隆远程仓库4. 切换检索当前分支5. 拉取并合并主干代码6. 推送代码到指定分支7. 提交到本地仓库 commit8. 本地代码 commit 后不想推送到远程分支回滚 注意事项结束语 每个人都在主宰自己的命运,人有选择&…

电脑软件:推荐一款非常强大的视频音频转换剪辑工具FFmpeg Batch AV Converter V3.12

目录 一、软件介绍 二、软件功能 三、软件特点 四、使用技巧 在多媒体处理领域,FFmpeg Batch AV Converter以其强大的功能和便捷的操作方式,成为了许多用户的首选工具。这款软件以其高效的批量处理能力、直观的图形用户界面(GUI&#xff…