热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

开发笔记:每篇半小时1天入门MongoDB——3.MongoDB可视化及shell详解

本篇主要介绍MongoDB可视化操作以及shell使用及命令,备份恢复、数据导入导出。MongoVUE安装和简单使用使用mongo.exe 管理数据库虽然可行,功能也挺强大,但每次都要敲命令,即繁琐枯

本篇主要介绍MongoDB可视化操作以及shell使用及命令,备份恢复、数据导入导出。

MongoVUE安装和简单使用

使用mongo.exe 管理数据库虽然可行,功能也挺强大,但每次都要敲命令,即繁琐枯燥而且效率低下。MongoDb在Windows下的可视化操作的管理工具非常多,笔者从中找了几款使用了一翻,最后挑了一款MongoVUE来最简单介绍,因为笔者觉得MongoVUE界面看上去舒服些。

下载地址:http://www.mongovue.com/downloads/

注意:官方提供的是收费版,试用期15天。但是天朝的东西,你懂的,破解很容易。

运行效果如下图所示。

 技术分享

添加数据库连接之前,要先运行Mongo服务,然后添加Mongo数据库连接,如下图所示。

技术分享技术分享技术分享

Document数据插入


> show collections
persons
system.indexes
> db.persons.find()
{
"_id" : ObjectId("593959250ab68d9cc7011a93"), "name" : "玉杰" }
{
"_id" : ObjectId("59395c350ab68d9cc7011a94"), "name" : "楚留香" }


1.插入文档

db.[documentName].insert({})

2.批量插入文档



  • shell这样执行是错误的:db.[documentName].insert([{},{},...])

  • shell不支持批量插入

  • 想完成批量插入可以使用Mongo的应用驱动或者是shell的for循环


> for(var i=0;i<10;i++){
... db.persons.insert({name:‘test‘
+i})}
WriteResult({
"nInserted" : 1 })
> db.persons.find()
{
"_id" : ObjectId("593959250ab68d9cc7011a93"), "name" : "玉杰" }
{
"_id" : ObjectId("59395c350ab68d9cc7011a94"), "name" : "楚留香" }
{
"_id" : ObjectId("593b489e29b0f45384dfaafa"), "name" : "test0" }
{
"_id" : ObjectId("593b489e29b0f45384dfaafb"), "name" : "test1" }
{
"_id" : ObjectId("593b489e29b0f45384dfaafc"), "name" : "test2" }
{
"_id" : ObjectId("593b489e29b0f45384dfaafd"), "name" : "test3" }
{
"_id" : ObjectId("593b489e29b0f45384dfaafe"), "name" : "test4" }
{
"_id" : ObjectId("593b489e29b0f45384dfaaff"), "name" : "test5" }
{
"_id" : ObjectId("593b489e29b0f45384dfab00"), "name" : "test6" }
{
"_id" : ObjectId("593b489e29b0f45384dfab01"), "name" : "test7" }
{
"_id" : ObjectId("593b489e29b0f45384dfab02"), "name" : "test8" }
{
"_id" : ObjectId("593b489e29b0f45384dfab03"), "name" : "test9" }
>


3.Save操作

save操作和insert操作的区别在于当遇到_id相同的情况下,save完成保存操作,而insert则会报错

我们先来看下insert操作,先插入一条01的记录,然后再插入一条_id为01的记录会报错,因为_id重复了。

> db.persons.insert({_id:"01",name:1})
WriteResult({
"nInserted" : 1 })
> db.persons.insert({_id:"01",name:2})
WriteResult({
"nInserted" : 0,
"writeError" : {
"code" : 11000,
"errmsg" : "E11000 duplicate key error index: myTest.persons.$_id_ dup key: { : \\"01\\" }"
}
})
>

再来看下save操作,直接将_id为01的记录更新了,name由1更新为了2

> db.persons.save({_id:"01",name:2})
WriteResult({
"nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
> db.persons.find()
{
"_id" : ObjectId("593959250ab68d9cc7011a93"), "name" : "玉杰" }
{
"_id" : ObjectId("59395c350ab68d9cc7011a94"), "name" : "楚留香" }
{
"_id" : ObjectId("593b489e29b0f45384dfaafa"), "name" : "test0" }
{
"_id" : ObjectId("593b489e29b0f45384dfaafb"), "name" : "test1" }
{
"_id" : ObjectId("593b489e29b0f45384dfaafc"), "name" : "test2" }
{
"_id" : ObjectId("593b489e29b0f45384dfaafd"), "name" : "test3" }
{
"_id" : ObjectId("593b489e29b0f45384dfaafe"), "name" : "test4" }
{
"_id" : ObjectId("593b489e29b0f45384dfaaff"), "name" : "test5" }
{
"_id" : ObjectId("593b489e29b0f45384dfab00"), "name" : "test6" }
{
"_id" : ObjectId("593b489e29b0f45384dfab01"), "name" : "test7" }
{
"_id" : ObjectId("593b489e29b0f45384dfab02"), "name" : "test8" }
{
"_id" : ObjectId("593b489e29b0f45384dfab03"), "name" : "test9" }
{
"_id" : "01", "name" : 2 }
>


Document数据删除


1.删除列表中所有数据

db.[documentName].remove()
集合的本身和索引不会被删除。删除文档是永久性的,不能撤销,也不能恢复的。因此,在执行remove()函数前先用find()命令来查看下是否正确,是个比较好的习惯啦。

> db.persons.remove({})
WriteResult({
"nRemoved" : 13 })
> db.persons.find()
> show collections
persons
system.indexes
> db.system.indexes.find()
{
"v" : 1, "key" : { "_id" : 1 }, "name" : "_id_", "ns" : "myTest.persons" }
>


2.根据条件删除

删除集合persons中name等于yujie的记录

remove()函数可以接受一个查询文档作为可选参数来有选择性的删除符合条件的文档

先来插入几条测试记录

> db.persons.insert({name:"yujie"})
WriteResult({
"nInserted" : 1 })
> db.persons.insert({name:"zouqj"})
WriteResult({
"nInserted" : 1 })
> db.persons.find()
{
"_id" : ObjectId("593b4c5329b0f45384dfab04"), "name" : "yujie" }
{
"_id" : ObjectId("593b4c5e29b0f45384dfab05"), "name" : "zouqj" }
>

再来删除name等于yujie的记录

> db.persons.remove({name:"yujie"})
WriteResult({
"nRemoved" : 1 })
> db.persons.find()
{
"_id" : ObjectId("593b4c5e29b0f45384dfab05"), "name" : "zouqj" }
>


3.小技巧

如果你想清除一个数据量十分庞大的集合,直接删除该集合并且重新建立索引的办法比直接remove的效率要高很多。

Document数据更新

db.[documentName].update(参数1,参数2,[参数3],[参数4])


  • 参数1:查询的条件

  • 参数2:更新的字段

  • 参数3:如果不存在则插入

  • 参数4:是否允许修改多条记录


1.强硬的文档替换式更新操作

db.[documentName].update({查询器},{修改器})

> db.persons.insert({name:"yujie",age:29})
WriteResult({
"nInserted" : 1 })
> db.persons.find()
{
"_id" : ObjectId("593b4c5e29b0f45384dfab05"), "name" : "zouqj" }
{
"_id" : ObjectId("593b540529b0f45384dfab06"), "name" : "yujie", "age" : 29 }
> db.persons.update({name:"yujie"},{age:30})
WriteResult({
"nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
> db.persons.find()
{
"_id" : ObjectId("593b4c5e29b0f45384dfab05"), "name" : "zouqj" }
{
"_id" : ObjectId("593b540529b0f45384dfab06"), "age" : 30 }
>

原本我是想把name等于yujie的记录,将其age更新为30,可是会发现虽然age更新为30了,但是也把"name" : "yujie"直接给删除了。因为:强硬的更新会用新的文档替代老的文档,其实就相当于先删除再插入的操作。

2.主键冲突的时候会报错并且停止更新操作

因为是强硬替换,当替换的文档和已有的文档ID冲突的时候,系统会报错。

先来插入几条测试记录

> db.persons.insert({_id:1,name:"test1"})
WriteResult({
"nInserted" : 1 })
> db.persons.insert({_id:2,name:"test2"})
WriteResult({
"nInserted" : 1 })
> db.persons.find()
{
"_id" : ObjectId("593b4c5e29b0f45384dfab05"), "name" : "zouqj" }
{
"_id" : ObjectId("593b540529b0f45384dfab06"), "age" : 30 }
{
"_id" : 1, "name" : "test1" }
{
"_id" : 2, "name" : "test2" }
>

然后我们再来强硬更新,会发现报错了。

> db.personso.update({_id:1},{_id:2,name:"test2"})
WriteResult({
"nMatched" : 0, "nUpserted" : 0, "nModified" : 0 })
> db.persons.update({_id:1},{_id:2,name:"test2"})
WriteResult({
"nMatched" : 0,
"nUpserted" : 0,
"nModified" : 0,
"writeError" : {
"code" : 16837,
"errmsg" : "The _id field cannot be changed from {_id: 1.0} to {_id: 2.0}."
}
})
>


3.insertOrUpdate操作

db.[documentName].update({查询器},{修改器},true)

目的:查询器查出来数据就执行更新操作,查不出来就替换操作。

> db.persons.update({_id:3},{_id:3,name:"test3"},true)
WriteResult({
"nMatched" : 0, "nUpserted" : 1, "nModified" : 0, "_id" : 3 })
> db.persons.find()
{
"_id" : ObjectId("593b4c5e29b0f45384dfab05"), "name" : "zouqj" }
{
"_id" : ObjectId("593b540529b0f45384dfab06"), "age" : 30 }
{
"_id" : 1, "name" : "test1" }
{
"_id" : 2, "name" : "test2" }
{
"_id" : 3, "name" : "test3" }
>


4.批量更新操作

默认情况下,当查询器查询出多条数据的时候默认就修改第一条数据,如何实现批量修改:
db.[documentName].update({查询器},{修改器},false,true)

5.修改器【通过修改器来完成局部更新操作】



































































修改器名称语法说明示例
$set{$set:{field:value}}用于指定一个键值对,存在就修改,不存在就添加{$set:{name:”Leon”}}
$inc{$inc:{field:value}}只适用于数字类型的字段值修改,对指定字段进行增减指定数值{$inc:{age:1}}
$unset{$unset:{field:1}}删除指定的字段{$unset:{age:1}}
$push{$push:{field:value}}指定的字段必须是数组,否则中断,指定的字段不存在则创建{$push:{family:”brother”}}
$pushAll{$pushAll:{field:array}}要求同push,一次添加多个元素到数组{$pushAll:{family:[“father”,”mother”,”brother”]}}
$addToSet{$addToSet:{field:value}}将值插入匹配元素指定的数组中,如果该值已存在则不添加{$addToSet:{family:”sister”}
$pop{$pop:{field:value}}从指定字段中数组中删除一个值,value接受正数(最后一个)和负数(第一个),一般使用1和-1{$pop:{family:1}}
$pull$pull:{field:value}从指定字段中的数组中删除指定的一个值{$pull:{family:”father”}}
$pullAll{$pullAll:{field:array}}从指定字段中的数组中删除指定的所有值{$pullAll:{family:[“father”,”mother”]}}
$这是一个定位器非修改器,用于定位数组中的指定键 

6.$addToSet与$each结合完成批量数组更新

db.persons.update({_id:1},{$addToSet:{books:{$each:{"js","db"]}}})
$each会循环后面的数组把每一个数值进行$addToSet操作

7.存在分配与查询效率

当document被创建的时候DB为其分配内存和预留内存,当修改操作不超过预留内存的时候,则速度
非常快,反之,若超过了就要分配新的内存,从而消耗时间。

技术分享

 


推荐阅读
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • 本文详细介绍如何使用Python进行配置文件的读写操作,涵盖常见的配置文件格式(如INI、JSON、TOML和YAML),并提供具体的代码示例。 ... [详细]
  • MongoDB集群配置:副本集与分片详解
    本文详细介绍了如何在MongoDB中配置副本集(Replica Sets)和分片(Sharding),并提供了具体的步骤和命令,帮助读者理解并实现高可用性和水平扩展的MongoDB集群。 ... [详细]
  • 本文探讨了如何在编程中正确处理包含空数组的 JSON 对象,提供了详细的代码示例和解决方案。 ... [详细]
  • 本文详细介绍了中央电视台电影频道的节目预告,并通过专业工具分析了其加载方式,确保用户能够获取最准确的电视节目信息。 ... [详细]
  • 本文详细介绍了Java中org.neo4j.helpers.collection.Iterators.single()方法的功能、使用场景及代码示例,帮助开发者更好地理解和应用该方法。 ... [详细]
  • 本文深入探讨了 Java 中的 Serializable 接口,解释了其实现机制、用途及注意事项,帮助开发者更好地理解和使用序列化功能。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 2023年京东Android面试真题解析与经验分享
    本文由一位拥有6年Android开发经验的工程师撰写,详细解析了京东面试中常见的技术问题。涵盖引用传递、Handler机制、ListView优化、多线程控制及ANR处理等核心知识点。 ... [详细]
  • 从 .NET 转 Java 的自学之路:IO 流基础篇
    本文详细介绍了 Java 中的 IO 流,包括字节流和字符流的基本概念及其操作方式。探讨了如何处理不同类型的文件数据,并结合编码机制确保字符数据的正确读写。同时,文中还涵盖了装饰设计模式的应用,以及多种常见的 IO 操作实例。 ... [详细]
  • 本文介绍如何使用阿里云的fastjson库解析包含时间戳、IP地址和参数等信息的JSON格式文本,并进行数据处理和保存。 ... [详细]
  • 本文由瀚高PG实验室撰写,详细介绍了如何在PostgreSQL中创建、管理和删除模式。文章涵盖了创建模式的基本命令、public模式的特性、权限设置以及通过角色对象简化操作的方法。 ... [详细]
  • 深入解析JMeter中的JSON提取器及其应用
    本文详细介绍了如何在JMeter中使用JSON提取器来获取和处理API响应中的数据。特别是在需要将一个接口返回的数据作为下一个接口的输入时,JSON提取器是一个非常有用的工具。 ... [详细]
  • 本文介绍如何在现有网络中部署基于Linux系统的透明防火墙(网桥模式),以实现灵活的时间段控制、流量限制等功能。通过详细的步骤和配置说明,确保内部网络的安全性和稳定性。 ... [详细]
  • HBase运维工具全解析
    本文深入探讨了HBase常用的运维工具,详细介绍了每种工具的功能、使用场景及操作示例。对于HBase的开发人员和运维工程师来说,这些工具是日常管理和故障排查的重要手段。 ... [详细]
author-avatar
fanersai_668
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有