码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Java面试题以及答案---3. MongoDb


    MongoDB是什么?

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

    集合是一组文档(即上面的 users 集合)。集合相当于关系数据库中的表,但集合中的文档长度可不同(集合中的文档中的键值对个数可不同)、集合中文档的key可不同。向集合中插入第一个文档时,集合会被自动创建。

    2>文档

    文档是一组键值对,用{ }表示,字段之间用逗号分隔。相当于关系数据库中的一行(一条记录)。示例:一个文档

    {
        id: "1",
        name: "张三",
        age: 28,
        email: "zhangs@gmail.com"
    }
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    这样写是为了方便看字段,也可以写在一起{id:“1”,name:“张三”,age:28,email:“zhangs@gmail.com”},一样的。
    说明:
    文档中的键值对是有序的
    一个文档中不能有重复的key(对应关系数据库中的一条记录)
    以"_"开头的key是保留的,有特殊含义。

    3>字段

    即一个键值对,key必须是String类型,value可以是任意类型。

    3.2 MongoDB和关系型数据库mysql区别
    在这里插入图片描述
    上图中,左边的是 MySQL 数据库中 users 表,右边是 MongoDB 中 users 集合。虽然表现形式不同,但是数据内容还是一样的。其中:

    test:表示数据库
    users:表示集合,类似MySQL中的表
    {id:“1”,name:“张三”,age:28,email:“zhangs@gmail.com”}:表示一个文档,类似于MySQL中的记录
    id、name、age和email:表示字段

    在这里插入图片描述
    3.3 MongoDB有3个数据库

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

    3.4Mongo中的数据类型

    1. null
    2. false和true
    3. 数值
    4. UTF-8字符串
    5. 日期 new Date()
    6. 正则表达式
    7. 数组
    8. 嵌套文档
    9. 对象ID ObjectId()
    10. 二进制数据
    11. 代码

    3.5 MongoDB适用业务场景

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

    Java最新课程:

    Java零基础视频教程(2022最新Java入门,含斯坦福大学练习题+力扣算法题

    Java基础入门:

    java零基础自学首Java入门教程(含Java项目和Java真题)

    Javaweb核心基础

    JavaWeb基础教程,Java web从入门到企业实战完整版

    Spring Cloud最全微服务架构:

    史上最全面的springcloud微服务技术栈

    SSM框架教程:

    SSM框架教程_Spring+SpringMVC+Maven高级+Spring

    SpringBoot2全套视频教程:

    SpringBoot2全套视频教程,springboot零基础到项目实战

  • 相关阅读:
    一段时间后,stop-dfs.sh关不掉Hadoop3.1.3集群,stop-hbase.sh关不掉HBase集群
    【架构】 第7章 主从复制高可用Redis集群
    es的数据存储结构;近实时查询原因
    11GR2 rac 2节点一键安装演示
    移动端适配
    【# 完美解决 node.js 模块化后报错 ReferenceError: require is not defined】
    Typora~Typora Markdown语法一站式教程
    Java—继承之题目练习
    【HMS Core】AOSP11安装/预置HMS Core 可以关闭限制广告跟踪吗?
    DNA修饰贵金属纳米颗粒|DNA脱氧核糖核酸修饰金属钯Pd纳米颗粒PdNPS-DNA
  • 原文地址:https://blog.csdn.net/Aa112233aA1/article/details/127408286
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号