当前位置: 首页 > news >正文

Java常见面试题-11-MongoDb

文章目录

  • MongoDB 是什么?
  • MongoDB 和关系型数据库 mysql 区别
  • MongoDB 有 3 个数据库分别是什么?
  • 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热爱者了解文章,作者将会持续更新中,期待各位友友的关注和收藏。。。

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • 非线性表之堆的实际应用和二叉树的遍历
  • 三数之和与四数之和 | LeetCode-15 | LeetCode-18 | 双指针 | 降维 | 哈希集合 | Java | 详细注释
  • Hive3:数据的加载与导出
  • 算法板子:欧拉函数——求一个数的欧拉函数、线性时间内求1~n所有数的欧拉函数
  • 宝兰德JVM参数查看及优化
  • 使用ubuntu串口数据收和发不一致问题
  • SpringAOP面向切面编程的概念和使用
  • 萱仔求职系列——1.1 机器学习基础知识复习
  • Redisson 实现分布式锁
  • vue2项目微信小程序的tabs切换效果
  • 学单片机怎么在3-5个月内找到工作?
  • 2024杭电多校(7) 1007. 创作乐曲【线段树预处理、dp、思维】
  • STM32的SDIO接口详解
  • 梅特勒金属探测器检测仪维修SAFELINE V3-QF1
  • 2024年电脑录屏软件推荐:捕捉屏幕,记录生活,分享精彩
  • [Vue CLI 3] 配置解析之 css.extract
  • Bootstrap JS插件Alert源码分析
  • css系列之关于字体的事
  • Elasticsearch 参考指南(升级前重新索引)
  • EOS是什么
  • GitUp, 你不可错过的秀外慧中的git工具
  • IOS评论框不贴底(ios12新bug)
  • Java知识点总结(JavaIO-打印流)
  • Lucene解析 - 基本概念
  • Python语法速览与机器学习开发环境搭建
  • Vue.js 移动端适配之 vw 解决方案
  • 飞驰在Mesos的涡轮引擎上
  • 官方新出的 Kotlin 扩展库 KTX,到底帮你干了什么?
  • 前端之React实战:创建跨平台的项目架构
  • 浅谈web中前端模板引擎的使用
  • 如何使用 OAuth 2.0 将 LinkedIn 集成入 iOS 应用
  • 微信开源mars源码分析1—上层samples分析
  • 你对linux中grep命令知道多少?
  • AI算硅基生命吗,为什么?
  • 蚂蚁金服CTO程立:真正的技术革命才刚刚开始
  • ​520就是要宠粉,你的心头书我买单
  • #Z0458. 树的中心2
  • $var=htmlencode(“‘);alert(‘2“); 的个人理解
  • ()、[]、{}、(())、[[]]等各种括号的使用
  • (145)光线追踪距离场柔和阴影
  • (6)【Python/机器学习/深度学习】Machine-Learning模型与算法应用—使用Adaboost建模及工作环境下的数据分析整理
  • (DenseNet)Densely Connected Convolutional Networks--Gao Huang
  • (k8s)Kubernetes本地存储接入
  • (Windows环境)FFMPEG编译,包含编译x264以及x265
  • (附程序)AD采集中的10种经典软件滤波程序优缺点分析
  • (附源码)小程序 交通违法举报系统 毕业设计 242045
  • (十八)devops持续集成开发——使用docker安装部署jenkins流水线服务
  • (十一)JAVA springboot ssm b2b2c多用户商城系统源码:服务网关Zuul高级篇
  • (一)认识微服务
  • (译)2019年前端性能优化清单 — 下篇
  • (源码版)2024美国大学生数学建模E题财产保险的可持续模型详解思路+具体代码季节性时序预测SARIMA天气预测建模
  • (转)linux下的时间函数使用
  • (转)大道至简,职场上做人做事做管理
  • (转载)Linux网络编程入门
  • (自适应手机端)响应式新闻博客知识类pbootcms网站模板 自媒体运营博客网站源码下载