第3章 MongoDB原理和使用V2.pptxVIP

  1. 1、本文档共74页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多

NoSQL数据库原理

第3章MongoDB的原理和使用;文档型数据库采用类似JSON的方式存储数据,因此可以建立比二维表更复杂的数据结构(称为富数据模型,RichDataModel)

文档型数据库一般也支持分布式架构、支持强横向扩展性、且具有弱一致性、弱事务等特点

MongoDB是一种知名的文档型NoSQL数据库

目前由独立公司(MongoDB公司)维护

主要特点有:支持复杂的数据结构,支持索引(包括二级索引和地理空间索引)、支持聚合查询,以及支持对大文件的存储与管理等

易用、分布式架构、易扩展、支持多副本

在物联网领域受到广泛关注

;MongoDB与MEANS

MEAN是指:MongoDB、Express、AngularJS和Node.js的松散组合

实现一种语言(Javascript)运行在应用程序的所有层次上,从客户端到服务器,再到持久层(的WEB开发方式)

“MEAN.JSisafull-stackJavaScriptsolutionthathelpsyoubuildfast,robust,andmaintainableproductionwebapplicationsusingMongoDB,Express,AngularJS,andNode.js.”

/

;3.2.1文档和集合

MongoDB会采用“文档”(Document)来表示描述数据的结构

{name:apple,color:red,taste:sweet}

一个文档可以看作一个数据条目,一组文档称为“集合”,可以类比于传统数据库中的“数据表”。

MongoDB采用BSON(BinaryJSON)来进行(文档的)存储与编码传输

BSON可以看作底层基于二进制方式存储的JSON,目前已经形成开放标准(V1.1)。

/models/16014/anime-lineart-style

;3.2.1文档和集合

BSON支持的常见数据类型如下:

ObjectID:对象ID,每个文档必须拥有一个唯一的ID。ID一般为12字节二进制数据。包括4字节时间戳、3字节设备ID、2字节进程ID和3字节计数器。

String:utf-8编码的字符串,在文档中使用双引号引用。

Boolean:布尔值,true或者false,在文档中不使用引号引用。

Integer:整数,在文档中不使用引号引用。整数具有32位(int)和64位(long)两种类型。

Double:浮点数,在文档中不使用引号引用。如果使用128位浮点数,则可以使用Decimal类型。

Arrays:数组或者列表。

Object:嵌入文档,一个值为一个文档。

Null:空值。

;3.2.1文档和集合

BSON支持的常见数据类型如下:

Timestamp:时间戳。

Minkey/Maxkey:BSON中的最低值和最高值。

Date:UNIX格式的日期或时间。

BinaryDate:二进制数据,别名为binData。

Bson中还包括正则表达式、JavaScript代码等。

通过支持Arrays,文档可以支持嵌套;3.2.2Yaml格式

全称是YAMLAintMarkupLanguage,是一个递归缩写,早期是YetAnotherMarkupLanguage,目前常用的是1.2版本

Cassandra利用Yaml编制配置文件(Cassandra.yaml)

基本原则

大小写敏感。

每行记录一个元素。如果第一个字符是“#”,则表示该行为注释。

字符串可以不使用引号包括,但如果字符串中含有特殊字符,例如“:”,则需要用单引号或双引号整体包括起来。

采用缩进表示层级关系,但缩进不允许使用tab键,只允许使用空格。缩进时使用的空格数量并不重要,但相同的空格数,表示相同层级的元素(即同层级元素要左对齐)。

;3.2.2Yaml格式

键值对,注意冒号之后的空格

fruit:apple

数组:(注意:缩进不允许使用tab键,只允许使用空格)

Player:

firstname:micheal

lastname:Jordan

team:Chicagobull

布尔型

retired:yes|no

retired:TRUE|true|True

;3.2.2Yaml格式

键值对(注意冒号之后的空格)

fruit:apple

文档:(注意缩进只允许使用空格)

{firstname:micheal,lastname:Jordan,team:Chicagobull}

Player:

firstname:micheal

lastname:Jo

文档评论(0)

学海无涯而人有崖 + 关注
实名认证
文档贡献者

教师资格证、人力资源管理师持证人

该用户很懒,什么也没介绍

领域认证该用户于2023年06月11日上传了教师资格证、人力资源管理师

1亿VIP精品文档

相关文档