Java常见面试题-11-MongoDb

文章目录

  • [MongoDB 是什么?](#MongoDB 是什么?)
  • [MongoDB 和关系型数据库 mysql 区别](#MongoDB 和关系型数据库 mysql 区别)
  • [MongoDB 有 3 个数据库分别是什么?](#MongoDB 有 3 个数据库分别是什么?)
  • [MongoDB 中的数据类型](#MongoDB 中的数据类型)
  • [MongoDB 适用业务场景](#MongoDB 适用业务场景)

MongoDB 是什么?

mongodb 是属于文档型非关系型数据库 ,是开源、高性能、高可用、可扩展的。其数据逻辑层次关系为文档=>集合=>数据库 。在关系型数据库中每一行的数据对应 mongodb 里是一个文档。mongodb 的文档是以 BSON(binary json)格式存储的,其格式就是 json 格式

  1. 集合
    集合是一组文档。集合相当于关系数据库中的表,但集合中的文档长度可不同(集合中的文档中的键值对个数可不同)、集合中文档的 key 可不同。向集合中插入第一个文档时,集合会被自动创建。
  2. 文档
    文档是一组键值对,用{ }表示,字段之间用逗号分隔。相当于关系数据库中的一行(一条记录)
  • 文档中的键值对是有序的
  • 一个文档中不能有重复的 key(对应关系数据库中的一条记录)
  • 以"_"开头的 key 是保留的,有特殊含义。
  1. 字段
    即一个键值对,key 必须是 String 类型,value 可以是任意类型。

MongoDB 和关系型数据库 mysql 区别

关系数据库 MongoDB
数据库 database 数据库 database
表格 table 集合 collection
行 row 文档 document
列 column 字段 field
索引 index 索引 index
表联合 table joins 嵌入文档
主键 primary 主键 primary key 。MongoDB默认主键为_id

MongoDB 有 3 个数据库分别是什么?

一个 MongoDB 中可以建立多个数据库,这些数据库是相互独立的,有自己的集合和权限。不同的数据库使用不同的文件存储(不存储在一个文件中)。

MongoDB 默认有 3 个数据库:

  • admin: 从权限的角度来看,这是"root"数据库。将一个用户添加到这个数据库,这个用户会自动继承所有数据库的权限。一些特定的服务器端命令也只能在这个数据库中运行,比如列出所有的数据库或者关闭服务器。
  • local: 这个数据库永远不会被复制,里面的数据都是本地的(不会复制到其他 MongoDB 服务器上),可以用来存储限于本地单台服务器的任意集合。
  • config: 当 Mongo 用于分片设置时,config 数据库在内部使用,用于保存分片的相关信息。

MongoDB 中的数据类型

  • null
  • false 和 true
  • 数值
  • UTF-8 字符串
  • 日期 new Date()
  • 正则表达式
  • 数组
  • 嵌套文档
  • 对象 ID ObjectId()
  • 二进制数据
  • 代码

MongoDB 适用业务场景

  • 网站数据:MongoDB 非常适合实时的插入,更新与查询,并具备网站实时数据存储所需的复制及高度伸缩性。
  • 缓存:由于性能很高,MongoDB 也适合作为信息基础设施的缓存层。在系统重启之后, 由 MongoDB 搭建的持久化缓存层可以避免下层的数据源过载。
  • 大尺寸,低价值的数据:使用传统的关系型数据库存储一些数据时可能会比较昂贵,在此之前,很多时候程序员往往会选择传统的文件进行存储
  • 高伸缩性的场景:MongoDB 非常适合由数十或数百台服务器组成的数据库。MongoDB 的路线图中已经包含对 MapReduce 引擎的内置支持
  • 用于对象及 JSON 数据的存储:MongoDB 的 BSON 数据格式非常适合文档化格式的存储及查询.

欢迎java热爱者了解文章,作者将会持续更新中,期待各位友友的关注和收藏。。。

相关推荐
CUIYD_198921 小时前
Eclipse 常用搜索功能汇总
java·ide·eclipse
野犬寒鸦1 天前
力扣hot100:相交链表与反转链表详细思路讲解(160,206)
java·数据结构·后端·算法·leetcode
ytadpole1 天前
揭秘设计模式:工厂模式的五级进化之路
java·设计模式
计算机毕业设计木哥1 天前
计算机毕设选题:基于Python+Django的B站数据分析系统的设计与实现【源码+文档+调试】
java·开发语言·后端·python·spark·django·课程设计
失散131 天前
分布式专题——1.2 Redis7核心数据结构
java·数据结构·redis·分布式·架构
用户3721574261351 天前
Python 实现 HTML 转 Word 和 PDF
java
a587691 天前
Java核心概念精讲:TCP与UDP的区别、Java NIO的几个核心组件与HTTP和HTTPS的区别等(46-50)
java·面试·nio
渣哥1 天前
ConcurrentHashMap 的 get 要不要加锁?一次“多此一举”的心路历程
java
愿你天黑有灯下雨有伞1 天前
一种基于注解与AOP的Spring Boot接口限流防刷方案
java·spring boot·后端
MuMuMu#1 天前
JAVA NIO学习笔记基础强化学习总结
java·学习·nio