当前位置: 首页 > 编程日记 > 正文

mongodb 索引去重_朋友问你 MongoDB 是什么?给他看这篇就好了

点击▲关注 “ITPUB”   给公众号标星置顶更多精彩 第一时间直达
来源:hello_锦泰blog.csdn.net/hayre/article/details/80628431
总结的目的在于回顾MongoDB的相关知识点,明确MongoDB在企业级应用中充当的角色,为之后的技术选型提供一个可查阅的信息简报。
文章提纲:1、MongoDB是什么?2、为什么要使用MongoDB?3、主要特性4、C/S服务模型5、完善的命令行工具6、几个shell实操7、在Java中使用MongoDB

1、MongoDB是什么?

MongoDB是一款为web应用程序和互联网基础设施设计的数据库管理系统。没错MongoDB就是数据库,是NoSQL类型的数据库

2、为什么要用MongoDB?

(1)MongoDB提出的是文档、集合的概念,使用BSON(类JSON)作为其数据模型结构,其结构是面向对象的而不是二维表,存储一个用户在MongoDB中是这样子的。
1{2    username:'123',3    password:'123'4}
使用这样的数据模型,使得MongoDB能在生产环境中提供高读写的能力,吞吐量较于mysql等SQL数据库大大增强。(2)易伸缩,自动故障转移。易伸缩指的是提供了分片能力,能对数据集进行分片,数据的存储压力分摊给多台服务器。自动故障转移是副本集的概念,MongoDB能检测主节点是否存活,当失活时能自动提升从节点为主节点,达到故障转移。(3)数据模型因为是面向对象的,所以可以表示丰富的、有层级的数据结构,比如博客系统中能把“评论”直接怼到“文章“的文档中,而不必像myqsl一样创建三张表来描述这样的关系。

3、主要特性

(1)文档数据类型
SQL类型的数据库是正规化的,可以通过主键或者外键的约束保证数据的完整性与唯一性,所以SQL类型的数据库常用于对数据完整性较高的系统。MongoDB在这一方面是不如SQL类型的数据库,且MongoDB没有固定的Schema,正因为MongoDB少了一些这样的约束条件,可以让数据的存储数据结构更灵活,存储速度更加快。
(2)即时查询能力
MongoDB保留了关系型数据库即时查询的能力,保留了索引(底层是基于B tree)的能力。这一点汲取了关系型数据库的优点,相比于同类型的NoSQL redis 并没有上述的能力。
(3)复制能力
MongoDB自身提供了副本集能将数据分布在多台机器上实现冗余,目的是可以提供自动故障转移、扩展读能力。
(4)速度与持久性
MongoDB的驱动实现一个写入语义 fire and forget ,即通过驱动调用写入时,可以立即得到返回得到成功的结果(即使是报错),这样让写入的速度更加快,当然会有一定的不安全性,完全依赖网络。 MongoDB提供了Journaling日志的概念,实际上像mysql的bin-log日志,当需要插入的时候会先往日志里面写入记录,再完成实际的数据操作,这样如果出现停电,进程突然中断的情况,可以保障数据不会错误,可以通过修复功能读取Journaling日志进行修复。
(5)数据扩展
MongoDB使用分片技术对数据进行扩展,MongoDB能自动分片、自动转移分片里面的数据块,让每一个服务器里面存储的数据都是一样大小。

4、C/S服务模型

MongoDB核心服务器主要是通过mongod程序启动的,而且在启动时不需对MongoDB使用的内存进行配置,因为其设计哲学是内存管理最好是交给操作系统,缺少内存配置是MongoDB的设计亮点,另外,还可通过mongos路由服务器使用分片功能。MongoDB的主要客户端是可以交互的js shell 通过mongo启动,使用js shell能使用js直接与MongoDB进行交流,像使用sql语句查询mysql数据一样使用js语法查询MongoDB的数据,另外还提供了各种语言的驱动包,方便各种语言的接入。

5、完善的命令行工具

mongodump和mongorestore,备份和恢复数据库的标准工具。输出BSON格式,迁移数据库。mongoexport和mongoimport,用来导入导出JSON、CSV和TSV数据,数据需要支持多格式时有用。mongoimport还能用与大数据集的初始导入,但是在导入前顺便还要注意一下,为了能充分利用好mongoDB通常需要对数据模型做一些调整。mongosniff,网络嗅探工具,用来观察发送到数据库的操作。基本就是把网络上传输的BSON转换为易于人们阅读的shell语句。因此,可以总结得到,MongoDB结合键值存储和关系数据库的最好特性。因为简单,所以数据极快,而且相对容易伸缩还提供复杂查询机制的数据库。MongoDB需要跑在64位的服务器上面,且最好单独部署,因为是数据库,所以也需要对其进行热备、冷备处理。

6、几个shell实操

因为本篇文章不是API手册,所有这里对shell的使用也是基础的介绍什么功能可以用什么语句,主要是为了展示使用MongoDB shell的方便性,如果需要知道具体的MongoDB shell语法可以查阅官方文档。
1、切换数据库
1use dba
创建数据库并不是必须的操作,数据库与集合只有在第一次插入文档时才会被创建,与对数据的动态处理方式是一致的。简化并加速开发过程,而且有利于动态分配命名空间。如果担心数据库或集合被意外创建,可以开启严格模式
2、插入语法
1db.users.insert({username:"smith"})2db.users.save({username:"smith"})
3、查找语法
1db.users.find()2db.users.count()
4、更新语法
 1db.users.update({username:"smith"},{$set:{country:"Canada"}}) 2//把用户名为smith的用户的国家改成Canada 3 4db.users.update({username:"smith"},{$unset:{country:1}}) 5//把用户名为smith的用户的国家字段给移除 6 7db.users.update({username:"jones"},{$set:{favorites:{movies:["casablance","rocky"]}}}) 8//这里主要体现多值修改,在favorties字段中添加多个值 910db.users.update({"favorites.movies":"casablance"},{$addToSet:{favorites.movies:"the maltese"}},false,true)11//多项更新
5、删除语法
1db.foo.remove() //删除所有数据2db.foo.remove({favorties.cities:"cheyene"}) //根据条件进行删除3db.drop() //删除整个集合
6、索引相关语法
1db.numbers.ensureIndex({num:1})2//创建一个升序索引3db.numbers.getIndexes()4//获取全部索引
7、基本管理语法
 1show dbs 2//查询所有数据库 3show collections 4//显示所有表 5db.stats() 6//显示数据库状态信息 7db.numbers.stats() 8//显示集合表状态信息 9db,shutdownServer()10//停止数据库11db.help()12//获取数据库操作命令13db.foo.help()14//获取表操作命令15tab 键 //能自动帮我们补全命令
以上的命令只是简单实例,假设如果你之前没有学习过任何数据库语法,同时开始学sql查询语法和MongoDB 查询语法,你会发现哪一个更简单呢?如果你使用的是java驱动去操作MongoDB,你会发现任何的查询都像Hibernate提供出来的查询方式一样,只要构建好一个查询条件对象,便能轻松查询(接下来会给出示例),博主之前熟悉ES6,所以入手MongoDB js shell完成没问题,也正因为这样简洁,完善的查询机制,深深的爱上了MongoDB。

7、在Java中使用MongoDB

1、使用maven引入jar包
这里引用的是最新的驱动包,提供了一套新的访问连接方式
1<dependency>2  <groupId>org.mongodbgroupId>3  <artifactId>mongodb-driver-syncartifactId>4  <version>3.8.0-beta3version>5dependency>
2、创建一个访问客户端
1MongoClient client = MongoClients.create(“mongodb://10.201.76.94:27017”);
3、获取集合数量
1public long count() {2        MongoClient client = this.getClient();3        MongoCollection<Document> collections= client.getDatabase("mongodb_db_name").getCollection("mongodb_collection_name");4        return collections.count();5    }
4、查询集合
 1public List<Document> find(Document params,Bson sort,int skip,int limit) { 2        MongoClient client = this.getClient(); 3        MongoCollection<Document> collections= client.getDatabase("mongodb_db_name").getCollection("mongodb_collection_name"); 4        List<Document> list = new ArrayList<Document>(Integer.valueOf(config.getPro("sync_limit"))); 5    collections.find(params).sort(sort).skip(skip).limit(limit).forEach(new Block<Document>() { 6            @Override 7            public void apply(Document document) { 8                list.add(document); 9            }10        });11        return list;12    }
这里只举例了简单的链接与简单的MongoDB操作,可见其操作的容易性。使用驱动时是基于TCP套接字与MongoDB进行通信的,如果查询结果较多,恰好无法全部放进第一服务器中,将会向服务器发送一个getmore指令获取下一批查询结果。插入数据到服务器时间,不会等待服务器的响应,驱动会假设写入是成功的,实际是使用客户端生成对象id,但是该行为可以通过配置配置,可以通过安全模式开启,安全模式可以校验服务器端插入的错误。

END

由ITPUB社区主办的第11届中国系统架构师大会(SACC2019)隆重启动,本届大会继续延用四大主线并行的演讲模式,设置业务系统架构设计、大数据平台架构设计、数字化转型实践和开源架构设计四大主线以及微服务、开源架构设计、云原生等分线,共1个主会场,20个技术专场,100+来自互联网、金融、制造业、电商等领域嘉宾。8.5折优惠购票限时进行中,点击进入大会官网。

5f886c10bdc4d792932a0a93982c3cd4.png

「在看」吗?92f469dbc0e063a686193eab7a6210c7.png

92f469dbc0e063a686193eab7a6210c7.png点击进入官网立享购票8.5折优惠~

相关文章:

Win32 API消息函数:GetMessagePos

函数功能&#xff1a;该函数返回表示屏幕坐标下光标位置的长整数值。此位置表示当上一消息由GetMessage取得时鼠标占用的点。 函数原型&#xff1a;DWORD GetMessagePos&#xff08;VOID&#xff09; 参数&#xff1a;无。 返回值&#xff1a;返回值给出光标位置的X&a…

【组队学习】【29期】11. 青少年编程(Scratch 二级)

11. 青少年编程&#xff08;Scratch 二级&#xff09; 航路开辟者&#xff1a;王思齐、马燕鹏领航员&#xff1a;马燕鹏航海士&#xff1a;王思齐、马燕鹏 基本信息 开源内容&#xff1a;https://github.com/datawhalechina/team-learning-program/tree/master/Scratch内容属…

TP基础问题第一天

1、入口文件中定义的内容&#xff0c;说出3点 1. 检测PHP环境 if(version_compare(PHP_VERSION,5.3.0,<)) die(require PHP > 5.3.0 !); 2. 开启调试模式 建议开发阶段开启 部署阶段注释或者设为false define(APP_DEBUG,True); 3. 定义应用目录 define(APP_P…

均值聚类散点图怎么画_GraphPad Prism 绘图教程 | 手把手教你绘制Column散点图

散点图&#xff0c;最常见的散点图是数据在直角坐标系中的分布图&#xff0c;我们可以考察坐标点的分布&#xff0c;判断两变量之间是否存在某种关联或总结坐标点的分布模式和趋势等&#xff1b;此外&#xff0c;我们还会用到多组数据的散点图&#xff0c;那我们如何来操作呢&a…

lucene3.0范围查找TermRangeQuery

原文链接:http://www.wenhq.com/article/view_415.html欢迎转载,请注明出处:亲亲宝宝 lucene3.0范围查找TermRangeQuery 在lucene3.0中&#xff0c;范围查询也有很大的变化&#xff0c;RangeQuery已经不推荐使用&#xff0c;使用TermRangeQuery和NumericRangeQuery两个替代。Te…

开源大数据周刊-第11期

摘要&#xff1a;开源有四个阶段&#xff1a;拥抱开源、回馈开源、融合开源、回报开源阿里云E-Mapreduce动态E-Mapreduce团队1.3.3版本 (已经发布)商业化发布&#xff0c;用户无需申请即可使用E-MapReduce服务1.3.4版本 (正在研发)升级jdk到1.8升级Hadoop到2.7.2添加python2.7.…

【青少年编程】【四级】绘制花瓣

「青少年编程竞赛交流群」已成立&#xff08;适合6至18周岁的青少年&#xff09;&#xff0c;公众号后台回复【Scratch】或【Python】&#xff0c;即可进入。如果加入了之前的社群不需要重复加入。 我们将有关编程题目的教学视频已经发布到抖音号21252972100&#xff0c;小马老…

一加7t人脸识别_一加7T系列国行版开启预约 谷歌Pixel 4系列高清图曝光

据一加手机官方消息&#xff0c;一加7T系列国行版已经开启预约&#xff0c;全新系列将于10月15日正式发布。一加7T采用6.55英寸&#xff0c;分辨率为24001080的AMOLED显示屏&#xff0c;具有90Hz刷新率、峰值亮度为1000尼特和HDR10 &#xff0c;采用屏下指纹。硬件方面&#xf…

MS IME 2007输入法

CH到JP 快捷键 ALTShift A到あ 快捷键 ctrlcaps lock 切换到片假 快捷键 altcaps lock 切换回来 快捷键 shiftcaps lock比如我输あした。本来按空格该出现"明日"的汉字三个假名下面的横线要是分开的话,你按住"SHIFT""左右箭头…

Weex第一天:手势

实验特征 Weex封装原生触摸事件以提供手势系统。使用手势类似于在Weex中使用事件。只需on在节点上设置属性即可收听手势。 类型 目前&#xff0c;有四种类型的手势&#xff1a; Touch。当触摸点被放置&#xff0c;移动或从触摸表面移除时&#xff0c;触摸手势被触发。触摸手势是…

【青少年编程(第30周)】关于青少年编程能力等级测评的科普!

2021年09月12日&#xff08;周日&#xff09;晚20:00我们在青少年编程竞赛交流群开展了第三十次直播活动。我们直播活动的主要内容如下&#xff1a; 首先&#xff0c;我们奖励了上周测试超过60分的小朋友。 其次&#xff0c;我们一起分析了电子学会Scratch四级的考试要求&…

ansys大变形开关要不要打开_ANSYS不收敛问题的解决办法

笔者应聘时发现此公众号内容也备受同行专家认可&#xff0c;继续努力&#xff0c;再接再厉&#xff01;本文经验是基于仿真秀专家学者总结&#xff0c;在此感谢仿真秀的支持与鼓励。80%的线性不收敛都是因为接触问题&#xff01;&#xff01;&#xff01;一、材料问题的不收敛可…

JAVA环境变量的配置

右键计算机—>属性—>高级系统设置—>环境变量&#xff0c;在用户变量那里添加jdk文件夹中的bin文件夹的路径&#xff0c;如&#xff1a; 变量名&#xff1a;PATH 值&#xff1a;E:\Program Files (x86)\Java\jdk1.7.0_09\bin 如果只是做java程序编译那么就可以用了&a…

【青少年编程】【四级】从小到大排序

「青少年编程竞赛交流群」已成立&#xff08;适合6至18周岁的青少年&#xff09;&#xff0c;公众号后台回复【Scratch】或【Python】&#xff0c;即可进入。如果加入了之前的社群不需要重复加入。 微信后台回复“资料下载”可获取以往学习的材料&#xff08;视频、代码、文档&…

ulimit -n 修改

通过ulimit -n命令可以查看linux系统里打开文件描述符的最大值&#xff0c;一般缺省值是1024&#xff0c;对一台繁忙的服务器来说&#xff0c;这个值偏小&#xff0c;所以有必要重新设置linux系统里打开文件描述符的最大值。那么应该在哪里设置呢&#xff1f; 最正确的做法是在…

变频器参数设置_变频器接线和参数设置

工业上用的变频器&#xff0c;分为单相和三相两种&#xff0c;这个是从主回路供电的电压来区分的&#xff0c;三相就是主回路要接入RST三相380伏交流电&#xff0c;输出接UVW三相线给电机&#xff1b;而单相是主回路接入单相220伏LN交流电&#xff0c;输出同样接UVW三相线给电机…

【青少年编程】【二级】货运飞船

「青少年编程竞赛交流群」已成立&#xff08;适合6至18周岁的青少年&#xff09;&#xff0c;公众号后台回复【Scratch】或【Python】&#xff0c;即可进入。如果加入了之前的社群不需要重复加入。 我们将有关编程题目的教学视频已经发布到抖音号21252972100&#xff0c;小马老…

JavaScript系统对象

1. 本地对象&#xff08;非静态对象&#xff09; 常用对象有&#xff1a;   Object、Function、Array、String、Boolean、Number、Date、RegExp、Error   注&#xff1a;本地对象需要new之后再使用。 2. 内置对象&#xff08;静态对象&#xff09; Global、Math   注&…

循环map_python函数 map函数—比for还好用的循环

描述&#xff1a;产生一个将 function 应用于迭代器中所有元素并返回结果的迭代器。如果传递了额外的 iterable 实参&#xff0c;function 必须接受相同个数的实参&#xff0c;并使用所有迭代器中并行获取的元素。当有多个迭代器时&#xff0c;最短的迭代器耗尽则整个迭代结束。…

30分钟掌握STL

三十分钟掌握STL STL概述 STL的一个重要特点是数据结构和算法的分离。尽管这是个简单的概念&#xff0c;但这种分离确实使得STL变得非常通用。例如&#xff0c;由于STL的sort()函数是完全通用的&#xff0c;你可以用它来操作几乎任何数据集合&#xff0c;包括链表&#xff0c;容…

JavaSE基础:Arrays工具类

Java工具类: Arrays Arrays类是数组的操作类,定义在java.util包中,主要功能是实现数组元素的查找/数组内容的充填/排序等功能 1.排序数组的sort方法 重点:对数组元素进行排序操作,默认由小到大排序. 该方法的参数不仅可以是基础数据类型的数组&#xff0c;也可以是对象引用的数…

【青少年编程(第31周)】一个有趣又有料的抖音号!

2021年09月19日&#xff08;周日&#xff09;晚20:00我们在青少年编程竞赛交流群开展了第三十一次直播活动。我们直播活动的主要内容如下&#xff1a; 首先&#xff0c;我们奖励了上周测试超过30分的小朋友。 其次&#xff0c;我们讲解了上次测试中小朋友们做错的题目Scratch青…

android根据ip获取域名_android常用工具类 通过域名获取ip

/*** 编写多线程程序是为了实现多任务的并发执行&#xff0c;从而能够更好地与用户交互。* 一般有三种方法&#xff0c;Thread,Runnable,Callable.* Runnable和Callable的区别是&#xff0c;* (1)Callable规定的方法是call(),Runnable规定的方法是run().* (2)Callable的任务执行…

河南省第二届ACM程序设计大赛解题报告(置换群)

1. 1 /*2 前两道题一直在纠结提议&#xff0c;特别是第二题&#xff0c;看了别人的代码才明白过来题意&#xff0c;由测试用例都没明白 3 */4 #include <iostream>5 #include <cstring>6 #include <queue>7 using namespace std;8 9 const int maxn 55; 10 …

【青少年编程】【四级】创意画图

「青少年编程竞赛交流群」已成立&#xff08;适合6至18周岁的青少年&#xff09;&#xff0c;公众号后台回复【Scratch】或【Python】&#xff0c;即可进入。如果加入了之前的社群不需要重复加入。 我们将有关编程题目的教学视频已经发布到抖音号21252972100&#xff0c;小马老…

《机器学习实践》程序清单2-2

将文本记录转换为NumPy的解析程序 def file2matrix(filename):print("读入文件" str(filename))#以下两行为打开文本文件并读取内容到数组&#xff0c;有没有发现这个操作好简单&#xff1f;&#xff01;fr open(filename)arrayOLines fr.readlines() #把文件中的…

vba保存文件为xlsx格式_Vba把Excel某个范围保存为XLS工作薄文件

Dim wn$, shp As Shape, arrApplication.ScreenUpdating FalseApplication.DisplayAlerts Falsewn [a1]arr Range("o3:o" & Range("o65536").End(xlUp).Row)Sheets("报表").CopyWith ActiveWorkbookWith .Sheets(1).Rows("1:2"…

通过正则表达式查找一个模式的所有实例

这个功能就是一般的文本查找功能&#xff0c;比较实用&#xff0c;记录下来&#xff0c;说不定以后可以用到 <!DOCTYPE html> <html xmlns"http://www.w3.org/1999/xhtml"> <head><meta charset"utf-8" /><title>string的ma…

【青少年编程】【四级】奇偶之和

「青少年编程竞赛交流群」已成立&#xff08;适合6至18周岁的青少年&#xff09;&#xff0c;公众号后台回复【Scratch】或【Python】&#xff0c;即可进入。如果加入了之前的社群不需要重复加入。 我们将有关编程题目的教学视频已经发布到抖音号21252972100&#xff0c;小马老…

ThinkPHP子类继承Controller类的注意事项

在实际的开发中&#xff0c;往往有很多子类都继承自同一个父类&#xff0c;然后该父类再继承自框架内置类的需求。 比如: class Init extends Controller{...} class son1 extends Init{...} class son2 extends Init{...} .... 若在Init类中&#xff0c;重写了构造函数&#x…