mongodb介绍

mongodb介绍mongodb介绍

大家好,又见面了,我是你们的朋友全栈君。

一,memcached ,redis 属于key/value数据库

二,mongodb跟上面的区别是,它属于文档数据库,存储的是文档(Bson(基于json修改json串时,这个json串后面的数据位置不发生变化,介绍空间)->json的二进制)

内部引擎用JS解释器,把文档存储成bson结构,在查询是,转换为JS对象,并可以通过熟悉的js语法来操作。

三,与传统数据相比

传统数据库:结构化数据,定好了表结构后,每一行的内容,必是符合表结构的,就是说,列的个数类型都一样。

mongo文档数据库,表下的每篇文档都可以有自己独特的结构(电影评论,一张表管理所有评论与回复,在传统型数据库中至少要4张表,关联度很复杂)

四:mongo命令行可以写for循环等脚本

五,索引 

1,索引提高查询速度,降低写入速度,因此要权衡常用的查询字段,不必在太多列上建索引。

2,在mongo中索引可以按字段升序降序(1生效,-1降序)来创建索引,便于排序。

3,默认使用Btree来组织索引文件(穿件索引是会产生索引文件的,也是占用空间内存的),2.4版本后也允许建立hash索引。

4,db.find(query).explain(),如果输出显示|“cursor”:BasicCursor 说明没有索引发挥作用。

5,索引分类:普通索引(单列索引,多列索引),唯一索引(被加索引的key值唯一,否则报错 ,需设置unique:true),稀疏索引(如果被索引的字段的值是空的,将不建立索引与之相对,普通索引不管被索引字段的值是不是空的都会把该文档的field列的值认为null,并建索引)

6,对hash查询和Btree查询的介绍

二叉树(Btree):即二分法查询,根据大小范围缩小查询位置,具有排序特性,mysql具有此种查询方式。

哈希(hash):散列存储(即数据在硬盘上东一个西一条),它是根据hash算法,为每条数据指定存储位置,查找的时候也是根据hash算法瞬间找到数据位置具有很快的查询速度。但是由于散列存储,所以数据不具有排序聚合特性。不适合查询有序的集合数据。

6,replication set复制集

多台服务器维护相同的数据副本,提高服务器的可用性。

基本的一个primary(主节点),两个secondary(副本节点),三个节点两两相互通信,发送心跳信息(至于为什么两个副本也要通信是因为,如果主节点挂了,两副本要竞争)

7,shard分片,把数据分块存储(比如:1-1千万条数据放在shard1,1千万-2千万条数据放在shard2等)

数据存储到不同的分片需要通过mongos路由器,分发到指定的分片,怎么指定呢,在路由器与分片见有个configsvr,它不存储正真的数据,而是meta元信息,即某条数据在那个分片上的信息。

mongos查询某条数据时,要先找configsvr,询问得到该数据在那个shard上(当然要先设定好分片规则)

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/105984.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 如何解决vscode感叹号无法建立html文件的问题

    如何解决vscode感叹号无法建立html文件的问题今天是我使用vscode的第二天,没想到昨天还能用感叹号(!)建立文件模板的vscode今天却不行了,而且中途也重装过一次。虽然重装后能用感叹号(!)弄一个模板出来,但是在此新建文件的时候就没用了。所以我一直在思索为什么会这样,最终功夫不负有心人还是给我找到了。在此,谢谢那位给我指名方向的大佬。正确方法是输入html:5,然后回车就能出现模板了。因为vscode升级了,所以关于模板的设定可能出现了一些变化吧。在这里恳求大家了,如果各位读者觉得好用的话就动动小手点赞吧。拜托了。…

    2022年8月22日
    7
  • 四足机械狗

    四足机械狗机械狗目录机械狗写在前面计划1搭建模拟环境1.1先模拟条简单的狗腿(two-link)1.1.1ForwardKinematics1.1.2InverseKinematics1.1.3ForwardDynamics1.1.4InverseDynamics1.2模拟个复杂点的狗腿(three/four-link)1.3搭个全身1.4加入Contactmodelling1.5合到一起2控制器设计2.1PDcontroll2.2Impedance/forcecontr

    2022年6月5日
    43
  • 服务网关配置_服务网关作用

    服务网关配置_服务网关作用目录第一章Gateway介绍1.1、什么是Gateway1.2、为啥用Gateway第二章Gateway三大核心第三章Gateway工作流程第四章Gateway路由功能4.1、项目准备与启动4.2、工程搭建与测试4.3、配置自定义路由4.4、禁止默认的路由4.5、配置动态的路由4.6、用代码来配路由4.7、为下章节做准备第五章Gateway断言功能5.1、谓词:Path5.2、谓词:After5.3、谓词:Before5.4、谓词:Between5.5、谓词:Cookie5.6、谓词:Header

    2022年10月10日
    0
  • 从零开始学习EasyDarwin(概述篇)

    EasyDarin是什么  EasyDarwin是由国内开源流媒体团队维护的一款开源流媒体平台框架,从2012年12月创建并发展至今,从原有的单服务的流媒体服务器形式,扩展成现在的云平台架构的开源项目,更好地帮助广大流媒体开发者和创业型企业快速构建流媒体服务平台。EasyDarwin适合做什么  安防视频监控,移动互联网(安卓、IOS、微信)流媒体直播与点播,流媒体视

    2022年4月5日
    43
  • java jks 转pfx_JKS和PFX文件相互转换方法「建议收藏」

    java jks 转pfx_JKS和PFX文件相互转换方法「建议收藏」JKS(JavaKeysotre)格式和PFX(PKCS12)格式,是最常见的SSL证书格式文件,可以包含完整的证书密钥对,证书链和信任证书信息。PFX常用于WindowsIIS服务器,JKS常用语JAVA类的WEB服务器,如TOMCAT,WEBLOGIC,JBOSS,RESIGN,虽然近年来,这些服务器新的版本,都是可以同时支持PFX,JKS文件格式了,但是老的版本和免费版本,往往都只支持JK…

    2022年5月1日
    143
  • python生成exe文件运行闪退解决方法

    python生成exe文件运行闪退解决方法**python生成exe文件运行闪退解决方法:**用python写了一个程序,在python下运行是正常的,但是生成exe文件后运行闪退我当时怀疑是不是脱离的python解释器就运行不了的问题,网上找了一通也没有解决。1.可能是程序运行结束,窗口自然就默默离开了。那么在源程序中加入用户输入字符后结束程序。input(“输入任意字符结束“)这样的。2.你编译成.exe的python程序…

    2022年4月28日
    80

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号