- 1、本文档共74页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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
您可能关注的文档
最近下载
- 金融银行实务民法典培训课件 .doc
- 普通遗传学试题库及答案概要.doc
- 学宪法--讲宪法.ppt
- SLT 778-2019 山洪沟防洪治理工程技术规范.pdf
- 七单元三位数除以两位数除法课时问题解决.pptx
- 魏晋南北朝文学(思维导图).pdf
- 2024年《药理学》专业知识考试题库及答案(A卷) .pdf VIP
- 标准图集 - 12J003 室外工程.pdf VIP
- 2022-2023学年北京市朝阳区七年级上学期期末地理试卷含答案.pdf VIP
- 人教版(2019) 选择性必修第一册 Unit 1 People of Achievement Reading and Thinking课件(共25张PPT).pptx VIP
文档评论(0)