Azure CosmosDB (11) MongoDB概念

  《Windows Azure Platform 系列文章目录

  

  Azure Cosmos DB兼容MongoDB的API,下表将帮助我们更容易理解MongoDB中的一些概念:

SQL概念 MongoDB概念 说明
Database Database 数据库
Table Collection 数据表/集合
Row Document 数据记录行/文档
Column Field 数字字段
Index Index 索引
Table Join   表连接,MongoDB不支持
Primary Key Primary Key 主键,MongoDB自动将_id字段设置为主键

  通过下图实例,我们也可以更直观的了解Mongo中的一些概念:

  

  文档Document

  文档是一组键值(key-value)对(即 BSON)。MongoDB 的文档不需要设置相同的字段,并且相同的字段不需要相同的数据类型,这与关系型数据库有很大的区别,也是 MongoDB 非常突出的特点。

  一个简单的文档例子如下:

  {"site":"http://www.cnblogs.com/threestone", "name":"我的博客"}

  需要注意的是:

  1. 文档中的键/值对是有序的。
  2. 文档中的值不仅可以是在双引号里面的字符串,还可以是其他几种数据类型(甚至可以是整个嵌入的文档)。
  3. MongoDB区分类型和大小写。
  4. MongoDB的文档不能有重复的键。
  5. 文档的键是字符串。除了少数例外情况,键可以使用任意UTF-8字符。

  集合Collection

  集合就是 MongoDB 文档组,类似于 RDBMS (关系数据库管理系统:Relational Database Management System)中的Table。

  集合存在于数据库中,集合没有固定的结构,这意味着你在对集合可以插入不同格式和类型的数据,但通常情况下我们插入集合的数据都会有一定的关联性。

  比如,我们可以将以下不同数据结构的文档插入到集合中:

  {"site":"www.baidu.com"}

  {"site":"www.google.com","name":"Google"}

  {"site":"http://www.cnblogs.com/threestone", "name":"我的博客"}

  MongoDB Relationship关系

  MongoDB的关系,表示多个Document之间在逻辑上的相互联系。

  文档间可以通过嵌入和引用来建议联系。

  MongoDB中的关系可以是:

  1. 1:1
  2. 1:N
  3. N:1
  4. N:N

  接下来,我们来考虑下用户与用户地址的关系。一个用户可以有多个地址,所以是一对多的关系。

  以下是user文档的简单结构:

{
"_id":ObjectId("52ffc33cd85242f436000001"),
"name": "Tom Hanks",
"contact": "987654321",
"dob": "01-01-1991"
}

以下是address文档的简单结构

{
   "_id":ObjectId("52ffc4a5d85242602e000000"),
   "building": "22 A, Indiana Apt",
   "pincode": 123456,
   "city": "Los Angeles",
   "state": "California"
} 

  嵌入式方法

  使用嵌入式方法,我们可以把用户地址嵌入到用户的文档中

{
   "_id":ObjectId("52ffc33cd85242f436000001"),
   "contact": "987654321",
   "dob": "01-01-1991",
   "name": "Tom Benzamin",
   "address": [
      {
         "building": "22 A, Indiana Apt",
         "pincode": 123456,
         "city": "Los Angeles",
         "state": "California"
      },
      {
         "building": "170 A, Acropolis Apt",
         "pincode": 456789,
         "city": "Chicago",
         "state": "Illinois"
      }]
} 

  以上数据保存在单一的文档中,可以比较容易的获取和维护数据。 你可以这样查询用户的地址:

>db.users.findOne({"name":"Tom Benzamin"},{"address":1})

  引用式关系

  引用式关系是设计数据库时经常用到的方法,这种方法把用户数据文档和用户地址数据文档分开,通过引用文档的 id 字段来建立关系。

{
   "_id":ObjectId("52ffc33cd85242f436000001"),
   "contact": "987654321",
   "dob": "01-01-1991",
   "name": "Tom Benzamin",
   "address_ids": [
      ObjectId("52ffc4a5d85242602e000000"),
      ObjectId("52ffc4a5d85242602e000001")
   ]
}

  

  以上实例中,用户文档的 address_ids 字段包含用户地址的对象id(ObjectId)数组。

  我们可以读取这些用户地址的对象id(ObjectId)来获取用户的详细地址信息。

  这种方法需要两次查询,第一次查询用户地址的对象id(ObjectId),第二次通过查询的id获取用户的详细地址信息。

>var result = db.users.findOne({"name":"Tom Benzamin"},{"address_ids":1})
>var addresses = db.address.find({"_id":{"$in":result["address_ids"]}})

原文地址:https://www.cnblogs.com/threestone/p/10684130.html

时间: 2024-10-19 00:42:24

Azure CosmosDB (11) MongoDB概念的相关文章

Azure DocumentDB对比MongoDB

(此文章同时发表在本人微信公众号"dotNET每日精华文章") 今天推荐的文章对Azure DocumentDB和MongoDB的进行了比较,也给出了一些使用建议. 我想很多朋友都应该知道Azure,不过估计也有很多人不知道微软还推出了自己的NoSQL数据库产品.当然这个产品仅限以PaaS的方式来在Azure中提供.DocumentDB去年秋天开始预览,这个正式上线(按照Azure的说法是Generally Available).当然,在NoSQL市场上,混战激烈,尤其MongoDB占

MongoDB 概念解析

MongoDB 概念解析 不管我们学习什么数据库都应该学习其中的基础概念,在mongodb中基本的概念是文档.集合.数据库,下面我们挨个介绍. 下表将帮助您更容易理解Mongo中的一些概念: SQL术语/概念 MongoDB术语/概念 解释/说明 database database 数据库 table collection 数据库表/集合 row document 数据记录行/文档 column field 数据字段/域 index index 索引 table joins   表连接,Mong

mongodb概念

一.mongodb与关系型数据库的一些概念上的改变 sql术语 mongodb术语 说明 database database 数据库 table collection 表/集合 row document 行/文档 column field 字段/域 index index 索引 table jions 表连接/mongodb不支持 primary key primary key 主键/mongodb将_id设置为主键 二.mongodb的bson bson是一种轻量级别的二进制的数据格式,使用b

MongoDB基础学习(一) MongoDB概念解析

.基础概念 SQL术语/概念 MongoDB术语/概念 说明 database database 数据库 table collection 数据表/集合 row document 数据记录行/文档 column field 数据字段/域 index index 索引 table joins   表连接,MongoDB不支持 primarg key primary key 主键 二.数据库 一个mongodb中可以建立多个数据库. MongoDB的默认数据库为"db",该数据库存储在da

MongoDB概念、安装和配置

1.概念 分布式文档存储,高读写吞吐量,自动灾备,可伸缩. 不需要遵守严格的数据schema意味着mongodb更灵活.更适合快速开发. 2.安装 2.1 yum 安装 配置yum源 = [mongodb-org-3.4] name=MongoDB?Repository baseurl=https://repo.mongodb.org/yum/redhat/$releasever/mongodb-org/3.4/x86_64/ gpgcheck=1 enabled=1 gpgkey=https:

Azure CosmosDB (13) CosmosDB数据建模

<Windows Azure Platform 系列文章目录> 我们在使用NoSQL的时候,如Azure Cosmos DB,可以非常快速的查询非结构化,或半结构化的数据.我们需要花一些时间,研究Cosmos DB的数据建模,来保证查询性能和可扩展性,同事降低成本. 阅读完这篇文章后,我们将学会: 1.什么是数据建模,为什么我们要关注数据建模 2.如何在Azure Cosmos DB进行数据建模,与传统关系型数据库有什么不同 3.如何在非关系型数据库中,保存关系型数据 4.什么时候执行嵌入(e

Azure China (11) 使用Azure China Storage Public Blob

<Windows Azure Platform 系列文章目录> 本文介绍的是国内由世纪互联运维的Azure China 注意:本文介绍的是Azure China Storage Public Blob,即可以通过匿名访问到Azure Storage云存储中的内容 项目源代码下载地址:http://files.cnblogs.com/files/threestone/AzurePublicBlob.rar 我们需要收集的内容如下: 1.Azure Storage Account Name 2.A

Azure China (11) 域名备案问题

<Windows Azure Platform 系列文章目录> (1) 默认情况下,我们在创建的Azure 服务,默认使用的DNS地址为: http://xxx.chinacloudapi.cn,这个DNS的根域名是世纪互联备案过的,如果客户只使用这个根域名,是不需要备案的 不过一般情况下,客户不会用微软Azure默认的DNS地址对外提供服务. (2) 如果客户不想使用Azure默认提供的DNS地址http://xxx.chinacloudapi.cn,想使用自己的二级域名(e.g. http

Azure ARM (11) ARM模式下,创建虚拟机并配置负载均衡器

<Windows Azure Platform 系列文章目录> 本文内容比较多,请大家仔细阅读,谢谢! 在前几章中,我们做了准备工作: 1.创建ARM Resouce Group,叫LeiResourceGroup 2.创建ARM Storage Account,叫leistorageaccount 3.创建ARM Virtual Network,叫LeiARMVNet 在本章中,笔者将介绍如何在ARM模式下,创建虚拟机VM.主要分为以下几步: 1.创建第一台ARM VM LeiARMWeb0