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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 共享打印机无法连接打印,错误代码0x0000011b_打印机共享错误0x000001

    共享打印机无法连接打印,错误代码0x0000011b_打印机共享错误0x000001WIndows无法连接共享打印机,错误码:0x0000011bWin10电脑1直连的打印机,设备了共享。从另一个电脑2访问电脑1的共享打印机,连接提示错误0x0000011b,如下:经询问使用人,之前电脑2是可以正常连接到电脑1的共享打印机的,只是最近几天突然连接失败了。后得知电脑1最近有更新过系统补丁。经排查,通过卸载KB5005565补丁,重启电脑1后,电脑2成功连接到共享打印机,测试打印正常。处理过程:1.打开控制面板-程序-程序和功能-已安装更新。找到对应的KB5005565补丁,右

    2025年10月21日
    3
  • JS刷新当前页面的五种方式

    JS刷新当前页面的五种方式https://www.jb51.net/article/44764.htm

    2022年7月27日
    7
  • 请慎用ASP.Net的validateRequest=”false”属性

    请慎用ASP.Net的validateRequest=”false”属性阅读全文下载代码:http://www.cckan.net/forum.php?mod=viewthread&tid=74在客户端的文体框里输入“例如”等字符的时候为出现这样的错误序安全的尝试,如跨站点的脚本攻击。通过在Page指令或配置节中设置validateRequest=false可以禁用请求验证。但是,在这种情况下,强烈建议应用程序显式检查所有输入。 异常

    2022年6月10日
    30
  • SecureCRT中文乱码解决方法(6)

    SecureCRT中文乱码解决方法(6)1、重新查看会话,是否中文显示正常2、依然无法正常显示中文,可能是由于Linux系统中默认的字符编码非UTF8所致用root用户登录。输入cat/etc/sysconfig/i18n如果安装系统为中文系统,则修改【LANG=“zh_CN.UTF-8”】如果安装系统为英文系统,则修改【LANG=“en_US.UTF-8”】保存文件。断开SSH,重新登录。就正常了下面是修改…

    2022年7月17日
    20
  • 运用平面向量的坐标求内积_向量数量积推导过程

    运用平面向量的坐标求内积_向量数量积推导过程Forpersonaluseonlyinstudyandresearch;notforcommercialuse平面向量内积的坐标运算与距离公式德清乾元职高朱见锋【教材分析】:本课是在平面向量坐标运算、内积定义基础上学习的,主要知识是平面向量内积的坐标运算与平面内两点间的距离公式,是后面学习曲线方程的重要公式和推导依据,是进一步学习相关数学知识的重要基础。【教学目标】1.掌握平面向量内积的坐标表示…

    2022年9月24日
    4
  • java转换字符串为时间_JAVA字符串转日期或日期转字符串

    java转换字符串为时间_JAVA字符串转日期或日期转字符串文章中,用的API是SimpleDateFormat,它是属于java.text.SimpleDateFormat,所以请记得import进来!用法:SimpleDateFormatsdf=newSimpleDateFormat(“yyyy-MM-ddHH:mm:ss”);这一行最重要,它确立了转换的格式,yyyy是完整的公元年,MM是月份,dd是日期,至于HH:mm:ss…

    2022年5月6日
    331

发表回复

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

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