首頁 資料庫 mysql教程 [教程]MongoDB 从入门到进阶 (概要 以及 高级索引篇 TimeToLive

[教程]MongoDB 从入门到进阶 (概要 以及 高级索引篇 TimeToLive

Jun 07, 2016 pm 05:56 PM
mongodb t 入門 教學 索引 進階 進階

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

MongoDB概要

[关于MongoDB]

    官方网站:

    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启动参数

 

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

 

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

 

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

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

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

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

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

 单击添加按钮

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

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

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

           端口:28030

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

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

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

界面右边的是当前连接的状态信息。 关于这些状态信息,你可以参看官方的帮助文档:

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

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

1 using System; 2 using System.Collections.Generic; 3 using System.Linq; 4 using System.Text; 5 using MongoDB.Driver; 6 using MongoDB.Bson; 7 using MongoDB.Driver.GridFS; 8 using MongoDB.Bson.Serialization.Attributes; MagicMongoDBTool.Module 11 { InitTestData 13 { User 15 { 16 [BsonId] 17 public String ID; )] 19 public String Name; 20 public Byte Age; 21 public Byte Age2; 22 public Byte Age3; 23 public Address address; 24 } Address 26 { 27 public String street; 28 public String City; 29 public String state; Zip; 31 32 } GeoObject 34 { 35 [BsonId] 36 public String ID; [] Geo; 38 } TLLObject 40 { 41 [BsonId] 42 public String ID; 43 public DateTime CreateDateTime; Game; 45 } FillDataForGeoObject(MongoServer mongosvr) 47 { ); ); 50 mongoCol.RemoveAll(); 51 Random Ro = new Random(); (int i = 0; i 1000; i++) 54 { 55 mongoCol.Insert(new GeoObject() 56 { 57 ID = i.ToString(), 58 Geo = new int[2] { Ro.Next() % 180, Ro.Next() % 180 } }); 61 } 62 } FillDataForTTL(MongoServer mongosvr) 64 { ); ); 67 mongoCol.RemoveAll(); 68 Random Ro = new Random(); (int i = 0; i 1000; i++) 71 { 72 mongoCol.Insert(new TLLObject() 73 { 74 ID = i.ToString(), 75 CreateDateTime = System.DateTime.Now.AddSeconds(i), 76 Game = Ro.Next() 77 }); 78 } 79 } FillDataForUser(MongoServer mongosvr) 81 { ); ); 85 mongoJsCol.Insert( , ) , )); 88 MongoGridFS mongofs = mongodb.GetGridFS(new MongoGridFSSettings()); ); 90 mongoCol.RemoveAll(); 91 Random Ro = new Random(); (int i = 0; i 1000; i++) 94 { 95 mongoCol.Insert(new User() 96 { 97 ID = i.ToString(), , 99 Age = (byte)Ro.Next(100), 100 Age2 = (byte)Ro.Next(100), 101 Age3 = (byte)Ro.Next(100), 102 address = new Address() 103 { , , , 107 Zip = Ro.Next(20) 108 } 109 }); 110 } 111 } 112 } 113 }

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

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

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

当然,如果你的英语还可以,原汁原味的在这里:+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索引的官方说明: 

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

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

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

[索引-GEO索引]

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

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

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

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

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

官方文档: 

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

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

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

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

                 4.Spherical(球形)

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

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

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

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

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

 

            

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

為什麼學線代時不知道:矩陣與圖竟然存在等價關係 為什麼學線代時不知道:矩陣與圖竟然存在等價關係 Aug 19, 2024 pm 04:52 PM

矩陣很難理解,但換個視角或許會不一樣。在學習數學時,我們常因所學知識的難度和抽象而受挫;但有些時候,只要換個角度,我們就能為問題的解答找到一個簡單又直觀的解法。舉個例子,小時候在學習和的平方(a+b)²公式時,我們可能不理解為什麼它等於a²+2ab+b²,只知道書上這麼寫,老師讓這麼記;直到某天我們看見了這張動圖:登時恍然大悟,原來我們可以從幾何角度來理解它!現在,這種恍然大悟之感又出現了:非負矩陣可以等價地轉換成對應的有向圖!如下圖所示,左邊的3×3矩陣其實可

高級引導教程:掌握自定義和組件 高級引導教程:掌握自定義和組件 Apr 04, 2025 am 12:04 AM

掌握Bootstrap自定義和組件使用的方法包括:1.使用CSS變量和Sass預處理器進行樣式自定義;2.深入了解並修改組件結構和行為。通過這些方法,可以創建獨特的用戶界面,提升網站的響應性和用戶體驗。

如何在Debian上配置MongoDB自動擴容 如何在Debian上配置MongoDB自動擴容 Apr 02, 2025 am 07:36 AM

本文介紹如何在Debian系統上配置MongoDB實現自動擴容,主要步驟包括MongoDB副本集的設置和磁盤空間監控。一、MongoDB安裝首先,確保已在Debian系統上安裝MongoDB。使用以下命令安裝:sudoaptupdatesudoaptinstall-ymongodb-org二、配置MongoDB副本集MongoDB副本集確保高可用性和數據冗餘,是實現自動擴容的基礎。啟動MongoDB服務:sudosystemctlstartmongodsudosys

火幣怎麼轉幣到幣安?如何把HTX裡面的加密資產提到幣安平台? 火幣怎麼轉幣到幣安?如何把HTX裡面的加密資產提到幣安平台? Mar 03, 2025 pm 08:51 PM

火幣到幣安轉賬指南:安全便捷地轉移您的加密資產許多投資者同時使用火幣和幣安這兩個知名的加密貨幣交易平台。本文將指導您如何安全地將火幣(HTX)上的加密資產,例如TRUMP和USDT,轉移到幣安(Binance)平台。幣安以其高安全性、豐富的幣種和交易對以及全球領先的交易量而備受青睞。幣安交易所的優勢:全球第一的交易量,佔據全球市場50%;儲備資產透明,主要為比特幣、以太坊和USDT等主流穩定幣;已有效規避美國SEC的潛在風險,是目前最穩定可靠的交易所之一。本教程將以TRUMP和USDT為例,演

MongoDB在Debian上的高可用性如何保障 MongoDB在Debian上的高可用性如何保障 Apr 02, 2025 am 07:21 AM

本文介紹如何在Debian系統上構建高可用性的MongoDB數據庫。我們將探討多種方法,確保數據安全和服務持續運行。關鍵策略:副本集(ReplicaSet):利用副本集實現數據冗餘和自動故障轉移。當主節點出現故障時,副本集會自動選舉新的主節點,保證服務的持續可用性。數據備份與恢復:定期使用mongodump命令進行數據庫備份,並製定有效的恢復策略,以應對數據丟失風險。監控與報警:部署監控工具(如Prometheus、Grafana)實時監控MongoDB的運行狀態,並

使用 Composer 解決推薦系統的困境:andres-montanez/recommendations-bundle 的實踐 使用 Composer 解決推薦系統的困境:andres-montanez/recommendations-bundle 的實踐 Apr 18, 2025 am 11:48 AM

在開發一個電商網站時,我遇到了一個棘手的問題:如何為用戶提供個性化的商品推薦。最初,我嘗試了一些簡單的推薦算法,但效果並不理想,用戶的滿意度也因此受到影響。為了提升推薦系統的精度和效率,我決定採用更專業的解決方案。最終,我通過Composer安裝了andres-montanez/recommendations-bundle,這不僅解決了我的問題,還大大提升了推薦系統的性能。可以通過一下地址學習composer:學習地址

Navicat查看MongoDB數據庫密碼的方法 Navicat查看MongoDB數據庫密碼的方法 Apr 08, 2025 pm 09:39 PM

直接通過 Navicat 查看 MongoDB 密碼是不可能的,因為它以哈希值形式存儲。取回丟失密碼的方法:1. 重置密碼;2. 檢查配置文件(可能包含哈希值);3. 檢查代碼(可能硬編碼密碼)。

幣安C2C是什麼?風險有哪些?安全嗎?幣安C2C買幣賣幣全教程 幣安C2C是什麼?風險有哪些?安全嗎?幣安C2C買幣賣幣全教程 Mar 05, 2025 pm 04:48 PM

幣安C2C交易指南:安全便捷的加密貨幣出入金方式本文將詳細解讀幣安C2C(CustomertoCustomer)交易模式,闡述其安全性、特點及操作流程,並提供圖文教程,幫助您輕鬆掌握幣安C2C出入金方法。什麼是幣安C2C?幣安C2C是幣安平台提供的用戶對用戶加密貨幣交易服務,為用戶提供便捷的加密貨幣與法幣兌換途徑。該服務於2019年推出,通過點對點交易模式,支持多種加密貨幣和法幣交易,並提供增強的安全保障和多種功能。與傳統的場外交易相比,幣安C2C平台對交易雙方進行身份驗證,並提供完善的支

See all articles