MongoDB+MongoVUE安装及入门[通俗易懂]

MongoDB+MongoVUE安装及入门[通俗易懂]前言及概念环境安装MongoDB的安装MongoVUE安装建立连接基础操作创建表添加数据查询日期查询排序Sort查询字段Fieldsskip跳过Limit分页修改删除数据前言及概念据说nodejs和mongoDB是一对好基友,于是就忍不住去学习了解了一下MongoDB相关的一些东西,那么,MongoDB是什么?这里的五件事是每个开放人员应该知道的:MongoDB是一

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


linux下安装MongoDB 4.0

戳这里《CentOS7 搭建MongoDB 4.0环境》

前言及概念

据说nodejs和mongoDB是一对好基友,于是就忍不住去学习了解了一下MongoDB相关的一些东西, 那么,MongoDB是什么?这里的五件事是每个开放人员应该知道的:

  • MongoDB是一个独立的服务器;

    • 如MySQL或PostreSQL 一样,MongoDB提供侦听端口以便接入。它提供了用于查询,创建,更新和删除的工具。从理论上讲,你使用它的工作方式相同:连接,执行任务并关闭连接
  • 它是基于文档的,而不是基于表格的;

    • MongoDB 没有结构化语言。如果你想创建一个新的文档类型,你不用做任何事来告诉数据库关于这些数据的结构,而仅仅是存到数据库中即可。

    • 简单的说,MongoDB使用类似JavaScript或PHP 的类型处理方式。也就是说,数据库是灵活的弱类型。

    • 虽然有一些数据是有限制条件的(大块的数据可能需要一些明确的处理),但在大多数情况下,你可以像写PHP代码一样编写你的MongoDB代码。

  • 它是非结构化的;

    • 还记得这些你写的数据库抽象层吗?还记得那些你处理过的ORM层吗?现在,你可以将它们全部丢弃。在MongoDB中你不需要他们。MongoDB没有很多查询语句。在大多数情况下,只需给它一个数组指定你想要的信息,然后它会给你返回文档的数组。如果你想运行一些非常复杂的查询(如Map-Reduce操作),可以向MongoDB传递JavaScript,其内部的JavaScript引擎可以解析这个脚本
  • 不必去学习另一种查询语言;

    • 开发时间也短,因为没有结构需要管理和很少(如果有的话)的数据映射。

    • 学习曲线很平滑,因为没有新的查询语言学习。代码是简洁的。毕竟,无须任何其他ORM,封装可以非常简单。你的代码是未来的保证。向你的对象增加更多的字段是很轻松的。因此,需求变化了,你可以很快修改代码以便适应。

    • MongoDB足以让我意识到它有改变游戏规则的潜力。这也是让大家主张使用新一代的文档数据库代替基于SQL的关系数据库的原因。将关系数据库留在尘土里,更可能的是让它们做它们能做好的事情:存储属于行和表的数据。

    • MongoDB 是用C++开发的面向文档的数据库,也就是反传统的数据库范式来设计的,把相关的对象都记录到一个文档里,每个文档内是schema-free的,也就是列名可以自由定义,比较灵活,特别是面对业务逻辑多变的应用场景十分给力。数据以BSON(类似JSON)的格式二进制存储。不好的地方就是可能带来一定的数据冗余和存储开销。

    • 另外,MongoDB的索引机制和MySQL等数据库是一样的,可以利用传统的关系数据库的经验来使用MongoDB的索引。

    • 不像其他很多NoSQL产品由个别工程师根据应用场景开发出来的,MongoDB是有一个专门的公司 10gen 来维护。有一点要注意的是,MongoDB自己是不管理内存的,无法指定内存大小,完全交给操作系统来管理,因此有时候是不可控的,在生产环境使用必须在OS层面监控内存使用情况。

  • 它具有强大的主流开发语言支持,如C#、C++、Java、PHP、Perl、Python、Ruby。

环境安装

MongoDB的安装

到这里mongodb就已经安装成功了。

  • 创建存储数据的文件夹
    如下图,在D盘下创建一个用于装数据的data文件夹。
    MongoDB+MongoVUE安装及入门[通俗易懂]

  • 指定数据存储路径并启动服务

  • 在cmd下进入刚刚mongoDB安装的路径,如下图:
    MongoDB+MongoVUE安装及入门[通俗易懂]

  • 启动服务
    执行指令:

    mongod --dbpath D:\data
    

    (这里注意前面是两个-,markdown不知道为什么显示出来就只有一个-了,见下图中的指令),其中D:\data为数据存放的位置。如下图这启动成功。
    MongoDB+MongoVUE安装及入门[通俗易懂]

  • 验证服务是否已经启动
    在浏览器下打开:http://localhost:27017/ ,如果出现下图效果则说明服务已经启动成功:
    MongoDB+MongoVUE安装及入门[通俗易懂]

MongoVUE安装

MongoDB+MongoVUE安装及入门[通俗易懂]

MongoDB+MongoVUE安装及入门[通俗易懂]

MongoDB+MongoVUE安装及入门[通俗易懂]

MongoDB+MongoVUE安装及入门[通俗易懂]

不多做解释,到此MongoVUE已经安装完成.

  • 补丁
    将解压zip下“补丁”文件夹中的“MongoVUE.exe”文件替换到安装文件目录下,如下图:
    MongoDB+MongoVUE安装及入门[通俗易懂]
    替换到
    MongoDB+MongoVUE安装及入门[通俗易懂]
    到此,已经完成。

建立连接

  • 先打开MongoVUE,按如下图流程
    MongoDB+MongoVUE安装及入门[通俗易懂]
    MongoDB+MongoVUE安装及入门[通俗易懂]
    MongoDB+MongoVUE安装及入门[通俗易懂]
    MongoDB+MongoVUE安装及入门[通俗易懂]
    MongoDB+MongoVUE安装及入门[通俗易懂]

基础操作

创建表

  • 右键数据库,点击add Collection,如下图:
    MongoDB+MongoVUE安装及入门[通俗易懂]
    MongoDB+MongoVUE安装及入门[通俗易懂]
    MongoDB+MongoVUE安装及入门[通俗易懂]

添加数据

  • 选择刚刚添加的表,右键,选择Insert/Import Documents,如下图:
    MongoDB+MongoVUE安装及入门[通俗易懂]
    MongoDB+MongoVUE安装及入门[通俗易懂]
    查看log日志
    MongoDB+MongoVUE安装及入门[通俗易懂]

    db.Test.insert({
    	Name:"张三",
    	Age:23,
    	Sex:"男",
    	Add:"XXX市XXX号XXX街道XXX号"
    });
    

查询

  • 如下图,最基础的查询:
    MongoDB+MongoVUE安装及入门[通俗易懂]

  • 基本查询,在{find}中输入Json
    如:{Name:“张三”}

    db.Test.find({ "Name" : "张三" }).limit(50);
    db.Test.find({ "Name" : "张三" }).limit(50).explain();
    

日期查询

  • 需要通过ISODate函数将日期进行格式话,如:{“InsertDate”:ISODate(“2016-03-09T16:00:00Z”)}

  • 查询大于,小于,大于等于,小于等于
    MongoDB+MongoVUE安装及入门[通俗易懂]

    db.Test.find({ "Age" : { "$gt" : 50 } }).limit(50);
    db.Test.find({ "Age" : { "$gt" : 50 } }).limit(50).explain();
    
     	\$lt:小于
     	\$lte:小于等于
     	\$gt:大于
     	\$gte:大于等于
    
  • 右击表格,点击Find2,比Find多了一个where;写表达式,如下图:
    MongoDB+MongoVUE安装及入门[通俗易懂]

    db.Test.find({ "$where" : "this.Age==23 || this.Age==50" }).limit(50);
    db.Test.find({ "$where" : "this.Age==23 || this.Age==50" }).limit(50).explain();
    

排序${Sort}

  • 如下图,在${Sort}中输入Json:{Age:-1},即对Age字段进行排序:
    MongoDB+MongoVUE安装及入门[通俗易懂]
    注:当大于0的时候为升序,小于0的时候则为降序
    db.Test.find({ "$where" : "this.Age==23 || this.Age==50" }).limit(50).sort({ "Age" : -1 });
    db.Test.find({ "$where" : "this.Age==23 || this.Age==50" }).limit(50).sort({ "Age" : -1 }).explain();
    

查询字段${Fields}

  • 如下图,查询_id和这些个字段{Name:1,Age:1}
    MongoDB+MongoVUE安装及入门[通俗易懂]
    db.Test.find({ "$where" : "this.Age==23 || this.Age==50" }, { "Name" : 1, "Age" : 1 }).limit(50).sort({ "Age" : -1 });
    db.Test.find({ "$where" : "this.Age==23 || this.Age==50" }, { "Name" : 1, "Age" : 1 }).limit(50).sort({ "Age" : -1 }).explain();
    

    注:当等于1的时候,就是查询_id和和等于1的字段;当如果等于0时,就是查询除了等于0的字段之外的所有字段,如下图:
    MongoDB+MongoVUE安装及入门[通俗易懂]

    db.Test.find({ "$where" : "this.Age==23 || this.Age==50" }, { "Name" : 0, "Age" : 0 }).limit(50).sort({ "Age" : -1 });
    db.Test.find({ "$where" : "this.Age==23 || this.Age==50" }, { "Name" : 0, "Age" : 0 }).limit(50).sort({ "Age" : -1 }).explain();
    

skip跳过

  • 当skip>0的时候表示跳过多少行,比如skip=1,表一起有2条数据,那么就只会查询出第二条数据。

Limit分页

  • 表示每次查询多少行,0的时候标识查询所有,>0则查询指定的行数。

修改

  • 右键表,选中update
    MongoDB+MongoVUE安装及入门[通俗易懂]
    db.Test.update({ "Age" : 24, "$isolated" : "true" },{$set:{Age:27,}});
    db.Test.find({Age:24});
    

删除数据

  • 右键表,选中remove,在窗口中输入如下json即可完成删除
    MongoDB+MongoVUE安装及入门[通俗易懂]
    db.Test.remove({ "Age" : 26 });
    

Over,后续有进一步研究,持续完善…

码字不易,感谢您的点赞!关注!评论!!!
在这里插入图片描述

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

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/125163.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • 发布版sha1怎么获取_sha1.rar

    发布版sha1怎么获取_sha1.rar获取SHA1值首先,绝大多数App在调试时使用的签名文件(debugkeystore)和最终App发布使用的签名文件(自定义的keystore)是不同的,不同签名文件的SHA1值也是不同的。下面提供几种获取SHA1值的方式:通过Eclipse编译器获取SHA1使用adt22以上版本,可以在eclipse中直接查看。Windows:依次在eclipse中打开Window->…

  • loadrunner性能测试步骤_loadrunner可以做接口测试吗

    loadrunner性能测试步骤_loadrunner可以做接口测试吗LoadRunner性能测试教程1.工具介绍及下载2.操作步骤2.1.VuGen脚本编写及运行2.2.Controller场景运行2.3.Alalysis分析1.工具介绍及下载LoadRunner,是一种预测系统行为和性能的负载测试工具。通过模拟上千万用户实施并发负载及实时性能监测的方式来确认和查找问题,LoadRunner能够对整个企业架构进行测试。企业使用LoadRunner能最大限度地缩短测试时间,优化性能和加速应用系统的发布周期。LoadRunner可适用于各种体系架构的自动负载测试,能预测系统

    2022年10月10日
  • python解释器在语法上不支持_语法测试

    python解释器在语法上不支持_语法测试1.安装Flake8必须在console中进行安装,示:pipinstallflake82.配置PycharmProgram:$PyInterpreterDirectory$/pythonarguments:-mflake8–max-line-length=130–excludevenv,migrations$ProjectFileDir$wor…

  • Redis管理工具安装和使用「建议收藏」

    Redis管理工具安装和使用「建议收藏」一、AnotherRedisDesktopManagergithub地址https://github.com/qishibo/AnotherRedisDesktopManagercsdn下载地址https://download.csdn.net/download/g313105910/18412412选择适合你的版本下载安装,后运行输入ip和密码然后就可以查看和修改数据了二、RedisDesktopManagergithub下载地址h

  • 申请SSL证书_免费永久证书

    申请SSL证书_免费永久证书腾讯云ssl证书是由受信任的权威数字证书颁发机构CA在验证服务器身份后颁发的一种数字证书(数字证书包括:SSL证书、客户端证书、代码签名证书等)。SSL本身是一种加密传输协议,因为配置在服务器上也称为服务器SSL证书。通过ssl证书安装部署,可以实现https访问网站,让网站安全可信赖。用户访问通过https访问网站时,在网站和用户之间提供一个加密通道,防止第三方通过该通道传输钓鱼网站、盗号木马等信息,进行信息拦截,避免资料泄露。SSL证书给用户最直观的感受是:1、地址栏出现绿色安全

  • C语言根据经纬度计算距离[通俗易懂]

    C语言根据经纬度计算距离[通俗易懂]#include#defineEARTH_RADIUS6378.137//地球半径#definePI3.14159265358979323846//Ô²ÖÜÂÊ//½Ç¶Èת»¯Îª»¡¶Èstaticdoublerad(doubled){  returnd*PI/180.0;}//µ±Äϱ±

发表回复

您的电子邮箱地址不会被公开。

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