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

MongoDB从入门到高级教程

MongoDB概要[关于MongoDB]官方网站:www.mongodb.comMongoDB属于比较典型的NoSql数据库。和Relationship数据库相比,其数据属于文档结构。最新版本的MongoDB为2.2.2不支持WindowsXP[C#官方驱动程序]GitHub:https://github.com/mo

MongoDB概要

[关于MongoDB]

    官方网站: www.mongodb.com

    MongoDB属于比较典型的NoSql数据库。和Relationship数据库相比,其数据属于文档结构。

    最新版本的MongoDB为2.2.2   不支持WindowsXP

[C#官方驱动程序]

     GitHub:https://github.com/mongodb/mongo-csharp-driver

[管理工具]

     这里选用本人自制的可视化管理工具作为教程的演示工具。

     大声呼吁:有兴趣的同志,加入这个工具的开发

     GitHub:   https://github.com/magicdict/MagicMongoDBTool

[建立第一个空数据库]

      关于MongoDB的安装,已经有很多文章介绍了。

      这里推荐CNBLOGS网友 百灵 的Mongodb之(初识如故)

      安装这篇文章,应该可以正确安装MongoDB,其实就是下载和解压,完全绿色软件。

      这个系列的教程,我将MongoDB解压到:C:\runmongo,可执行文件则都在C:\runmongo\bin下面。

      新建一个MongoDB实例的方法很多,这里我新建了一个BAT文件,在BAT文件里面写了3句命令:

      第一句:将执行目录切换到Mongo可执行目录

      第二句:新建一个目录,MongoDB实例需要一个存放文件的目录,这里我选择新建一个C:\mongodb\magicdict 目录

      第三句,则是新建一个MongoDB实例,同时,将MongoDB实例的侦听端口设置为 28030

     关于MongoDB的启动参数,推荐 咫尺天涯的文章:mongodb启动参数

 cd C:\runmongo\bin
 mkdir C:\mongodb\magicdict
 mongod --port  28030 --dbpath C:\mongodb\magicdict --rest

如果成功的话,将会有一个黑色的DOS控制台出现。当然,这个控制台只是日志输出,无法操作。你也可以将日志存放到一个文件里面。

 

这个时候去查看  C:\mongodb\magicdict,系统自动添加了一个 mongod.lock  锁文件。

接下来,启动可视化工具,看看数据库吧。

第一次启动时候,选择语言:

由于某些功能需要使用mongo的可执行文件,在可执行文件里面选择可执行文件路径

 下面是连接管理界面,里面列出了所有现存的连接

 单击添加按钮

          由于是最简单的数据库,我们只需要填写 连接名称,主机,端口号即可。

          连接名称:这个可以使任意字符,是便于用户记忆的。

          主机:这里填写服务器的IP地址,这里使用 localhost 表示本机

           端口:28030

这里你可以先使用 [测试] 按钮,检验一下设置是否正确。如果没有问题,则可以[添加]连接。

选中刚才建立的连接,按下[确定]按钮。则进入主界面。

界面左边的是当前连接(MongoDB实例)中所包含的数据库对象。当然,这个连接里面只是单纯的数据库。除了有一个系统自动生成的local数据库以外,什么都没有。

界面右边的是当前连接的状态信息。 关于这些状态信息,你可以参看官方的帮助文档: http://docs.mongodb.org/manual/reference/server-status/

 一般来说,我们不会在local系统目录里面添加数据,一般都会新建一个数据库来保存用户数据。

当然,你可以 选中Connection节点,然后用主菜单或者右键菜单来 [新建数据库]。不过,这里将演示如何使用C#来创建数据库,添加数据。

 using System;
 using System.Collections.Generic;
 using System.Linq;
 using System.Text;
 using MongoDB.Driver;
 using MongoDB.Bson;
 using MongoDB.Driver.GridFS;
 using MongoDB.Bson.Serialization.Attributes;
 namespace MagicMongoDBTool.Module
 {
     public static class InitTestData
     {
         internal class User
         {
             [BsonId]
             public String ID;
             [BsonElementAttribute("fn")]
             public String Name;
             public Byte Age;
             public Byte Age2;
             public Byte Age3;
             public Address address;
         }
         internal class Address
         {
             public String street;
             public String City;
             public String state;
             public int Zip;
         }
         internal class GeoObject
         {
             [BsonId]
             public String ID;
             public int[] Geo;
         }
         internal class TLLObject
         {
             [BsonId]
             public String ID;
             public DateTime CreateDateTime;
             public int Game;
         }
         public static void FillDataForGeoObject(MongoServer mongosvr)
         {
             MongoDatabase mongodb = mongosvr.GetDatabase("mongodb");
             MongoCollection mongoCol = mongodb.GetCollection("GEO");
             mongoCol.RemoveAll();
             Random Ro = new Random();
             ///HugeData
             for (int i = ; i < ; i++)
             {
                 mongoCol.Insert(new GeoObject()
                 {
                     ID = i.ToString(),
                     Geo = new int[] { Ro.Next() % , Ro.Next() %  }
                     //[-180,180] 如果已经有索引,则操作这个范围的记录无法插入数据库
                 });
             }
         }
         public static void FillDataForTTL(MongoServer mongosvr)
         {
             MongoDatabase mongodb = mongosvr.GetDatabase("mongodb");
             MongoCollection mongoCol = mongodb.GetCollection("TTL");
             mongoCol.RemoveAll();
             Random Ro = new Random();
             ///HugeData
             for (int i = ; i < ; i++)
             {
                 mongoCol.Insert(new TLLObject()
                 {
                     ID = i.ToString(),
                     CreateDateTime = System.DateTime.Now.AddSeconds(i),
                     Game = Ro.Next()
                 });
             }
         }
         public static void FillDataForUser(MongoServer mongosvr)
         {
             MongoDatabase mongodb = mongosvr.GetDatabase("mongodb");
             MongoCollection mongoJsCol = mongodb.GetCollection("system.js");
             mongoJsCol.Insert(
                           new BsonDocument().Add("_id", "sum")
                                             .Add("value", "function (x, y) { return x + y; }"));
             MongoGridFS mongofs = mongodb.GetGridFS(new MongoGridFSSettings());
             MongoCollection mongoCol = mongodb.GetCollection("User");
             mongoCol.RemoveAll();
             Random Ro = new Random();
             ///HugeData
             for (int i = ; i < ; i++)
             {
                 mongoCol.Insert(new User()
                 {
                     ID = i.ToString(),
                     Name = "Tom",
                     Age = (byte)Ro.Next(),
                     Age2 = (byte)Ro.Next(),
                     Age3 = (byte)Ro.Next(),
                     address = new Address()
                     {
                         street = "123 Main St.",
                         City = "Centerville",
                         state = "PA",
                         Zip = Ro.Next()
                     }
                 });
             }
         }
     }
 }

这里我新建了一个mongodb的数据库,同时新增了3个演示用数据集(collection)。

具体的操作方法,推荐 码农的文章:  MongoDB的C#驱动程序教程(译)

这里有非常详细的C#操作数据库的解释。全部是官方文档的翻译,可能是机器翻译的,但是对于英语不好的同志来说,有一定帮助。

当然,如果你的英语还可以,原汁原味的在这里:http://www.mongodb.org/display/DOCS/CSharp+Driver+Tutorial

MongoDB的对象存取,代码看上去有点ORM的味道,不过,由于MongoDB已经是阶层数据库了,完全不需要将Object进行映射(Map),而是直接存取到数据库中。

在简单类的时候,由于数据结构只是二维表格,这种优势不是很明显。在复杂类的时候,出现层次结构的时候,则效果非常明显。

下图则通过[树形视图]来直观展示了复杂阶层的类。

关系型数据库,需要将User数据和Address数据放在两张表中,然后用主键连接成视图。

阶层型数据库,则已经将User和Address信息放在一个文档(Document,类似于记录的概念)里面。

(当然,关系型的好处也非常明显,可以减少数据冗余,灵活性也非常好。阶层型数据库在编码上,可能更加贴近OOP)

 

 [索引-TTL索引]

 索引都是为了检索的性能而生的,MongoDB的索引也不例外。

 TTL(TimeToLive)索引(MongoDB2.2.2新增)和地理位置索引(“2d”)则是MongoDB的特色。

 TTL索引,索引对象是一个日期型字段,然后需要设定一个有效时间。通过监视 日期型字段的值和当前系统时间,参考有效时间,判断是否数据过期,对于过期的数据则自动删除。

 这个特性对于自动删除日志这样的操作来说,将非常有用。例如我们可以对于 日志创建时间 进行索引,同时设定过期时间为 3600秒,这样系统将自动删除一个小时之前的日志。

 这里我们准备了TTL这样的一个数据集:

 数据集里面包含了一个CreateDateTime的日期型字段,里面存放着建立记录的时间。

 接着我们选中数据集,通过索引管理器建立索引。

 我们将对于CreateDateTime建立所以,同时设定有效时间为180秒。

 这样的话,如果CreateDateTime和系统时间相差180秒,则记录将会被自动删除。

1.TTL索引必须建立在日期型字段(或者日期型字段数组)

2.不能建立在复杂索引上

3.你不能在 _id或者任何一个已经存在索引的字段上建立TTL索引

TTL索引的官方说明:  http://docs.mongodb.org/manual/tutorial/expire-data/

注意上面这张图的左边,显示了数据集的索引信息:

AutoDelete的索引过期时间为180秒。而默认的索引_id,则没有设定过期时间。

同时,里面的数据已经全部被系统自动删除掉了。

[索引-GEO索引]

如果,你的数据集里面有一个地理位置字段(所谓的地理位置字段,是一个数组,数组里面有两个数字,数字的范围是 [-180,180])。

例如,下面的Geo字段,就是一个地理位置字段。

 我们可以对于地理位置字段,进行“2d”索引,或者说是Geo索引。

观察一下索引类型:这里显示的是 “2d”,表示这是一个Geo地理索引

建立过地理索引的数据集,可以进行GeoNear查询。

官方文档:  http://docs.mongodb.org/manual/applications/geospatial-indexes/

GeoNear的意思就是:查询一下,指定的坐标附近,有那些记录。

你可以指定:  1.需要查询多少个最邻近的记录。

2.你可以限制最大的距离。

3.由于地理坐标的单位是弧度【-180,180】,有时候你需要将距离放大一些,你可以指定距离乘积

4.Spherical(球形)

下面我们要查询离坐标 【100,100】,距离在10以内的记录,我们限制最多查询100个记录。

并且我们不需要系统对于距离进行放大或者缩小的处理。

查询结果:我们扫描了23个记录(由于有索引,所以不需要扫描全部记录),扫描时间为0

符合条件的记录有6个,平均距离为 6.34 最大距离为 9.21

每条记录的详细信息都可以在结果里面看到。


推荐阅读
  • Allegro总结:1.防焊层(SolderMask):又称绿油层,PCB非布线层,用于制成丝网印板,将不需要焊接的地方涂上防焊剂.在防焊层上预留的焊盘大小要比实际的焊盘大一些,其差值一般 ... [详细]
  • 前面刚有AWS开战MongoDB,双方“隔空互呛”,这厢又曝出2亿+简历信息泄露——MongoDB的这场开年似乎“充实”得过分了些。长期以来,作为“最受欢迎的NoSQL数据库”,M ... [详细]
  • MongoDB学习:(二)MongoDB简单使用
    MongoDB学习:(二)MongoDB简单使用MongoDB使用:执行mongodb的操作之前,我们需要运行命令,来进入操作命令界面&amp;amp;gt;mongo提示 ... [详细]
  • 在Ubuntu中安装MongoDB
    nsitionalENhttp:www.w3.orgTRxhtml1DTDxhtml1-transitional.dtd ... [详细]
  • 在Docker中,将主机目录挂载到容器中作为volume使用时,常常会遇到文件权限问题。这是因为容器内外的UID不同所导致的。本文介绍了解决这个问题的方法,包括使用gosu和suexec工具以及在Dockerfile中配置volume的权限。通过这些方法,可以避免在使用Docker时出现无写权限的情况。 ... [详细]
  • 云原生边缘计算之KubeEdge简介及功能特点
    本文介绍了云原生边缘计算中的KubeEdge系统,该系统是一个开源系统,用于将容器化应用程序编排功能扩展到Edge的主机。它基于Kubernetes构建,并为网络应用程序提供基础架构支持。同时,KubeEdge具有离线模式、基于Kubernetes的节点、群集、应用程序和设备管理、资源优化等特点。此外,KubeEdge还支持跨平台工作,在私有、公共和混合云中都可以运行。同时,KubeEdge还提供数据管理和数据分析管道引擎的支持。最后,本文还介绍了KubeEdge系统生成证书的方法。 ... [详细]
  • Centos7.6安装Gitlab教程及注意事项
    本文介绍了在Centos7.6系统下安装Gitlab的详细教程,并提供了一些注意事项。教程包括查看系统版本、安装必要的软件包、配置防火墙等步骤。同时,还强调了使用阿里云服务器时的特殊配置需求,以及建议至少4GB的可用RAM来运行GitLab。 ... [详细]
  • [译]技术公司十年经验的职场生涯回顾
    本文是一位在技术公司工作十年的职场人士对自己职业生涯的总结回顾。她的职业规划与众不同,令人深思又有趣。其中涉及到的内容有机器学习、创新创业以及引用了女性主义者在TED演讲中的部分讲义。文章表达了对职业生涯的愿望和希望,认为人类有能力不断改善自己。 ... [详细]
  • 关于我们EMQ是一家全球领先的开源物联网基础设施软件供应商,服务新产业周期的IoT&5G、边缘计算与云计算市场,交付全球领先的开源物联网消息服务器和流处理数据 ... [详细]
  • 推荐系统遇上深度学习(十七)详解推荐系统中的常用评测指标
    原创:石晓文小小挖掘机2018-06-18笔者是一个痴迷于挖掘数据中的价值的学习人,希望在平日的工作学习中,挖掘数据的价值, ... [详细]
  • MongoDB用户验证auth的权限设置及角色说明
    本文介绍了MongoDB用户验证auth的权限设置,包括readAnyDatabase、readWriteAnyDatabase、userAdminAnyDatabase、dbAdminAnyDatabase、cluster相关的权限以及root权限等角色的说明和使用方法。 ... [详细]
  • hackingTeam是如何被黑的
    hackingTeam是如何被黑的 ... [详细]
  • MySQL:互联网公司常用 分库分表
    本文目录一、数据库瓶颈IO瓶颈CPU瓶颈二、分库分表水平分库水平分表垂直分库垂直分表三、分库分表工具四、分库分表步骤五、分库分表问题非partit ... [详细]
  • 《Python3 网络爬虫开发实战》:高效实用的 MongoDB 文档存储
    NoSQL,全称NotOnlySQL,意为不仅仅是SQL,泛指非关系型数据库。NoSQL是基于键值对的,而且不需要经过SQL ... [详细]
  • 架构师必读:日均500万数据,如何进行数据存储选型?
    点击上方关注我,选择“置顶或者星标”作者:麦田里的老农来源:https:zhuanlan.zhihu.comp37964096小编公司有一 ... [详细]
author-avatar
kanney姜_958
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有