作为PHP程序员应该了解MongoDB的五件事


Posted in PHP onJune 03, 2013

2010年应该被人们记住,因为SQL将在这一年死去。这一年关系数据库行将就木,这一年开发者发现他们再不需要长时间辛苦的构造列或者表格来存放数据。
2010年将是文档型数据库的起始年。尽管这样的势头已经持续多年,现在才是一个更多,更广泛的文档型数据库出现的年代。从基于云计算的Amazon到Google,大量开源工具,以及随之诞生的CouchDB和MongoDB。
那么什么是MongoDB?下面有五件事是PHP开发者应该了解的:
1. MongoDB是一个单独的服务器;
2. MongoDB是基于文档,而不是基于表;
3. MongoDB中较少的Schema;
4. 你不需要学习另外的语言;
5. MongoDB有良好的PHP支持。
1. MongoDB是一个单独的服务器
就像MySQL和PostgreSQL一样,MongoDB将监听接入的链接。它提供的工具作用包括询问,创建,更新和删除。理论上,你将跟在MySQL和PostgreSQL一样的进行工作:链接,处理,然后再关闭链接。
2. 向行和表说再见,欢迎文档和收集器
代替储存数据的表和行,MongoDB将数据储存在文档中。假如我们有一篇带标题的“文章”,它有多个作者,一个主题和标签。所有这些看起来就像下面:

array(
'title'=>'Hello World',
'authors'=>array('John','Sally','Jim'),
'body'=>'Hello world',
'tags'=>array('tag1','tag2','tag3')
);
?>

上面的例子中最关键的就是那一条记录——这篇文档——是的,确实存储起来就像是一篇文档,支持复合形式的值存储在同一区域。不再需要结构化,不需要将数据按照表来区分。因此,表已经不存在了。
3. MongoDB包含较少的schema
MongoDB没有schema语言。如果你想新建一种文档类型,你不需要告诉数据库任何事情。尽管将新的数据放到数据库中就行了。
在第二点中,我模拟了一个文档。现在我想为所有区域定义一个文章类型,所有我需要做的就是将这些数据写到数据库中。如果我决定延缓写入呢?我只需要拉出这部分数据,然后加上日期字段,最后保存就行。
那么数据类型怎么办?简单的回答就是MongoDB运用一种强制系统,类似JavaScript或者PHP。如此这样,数据库极好的弱化了类型的作用。
这有一些漏洞(超大量的数据需要一些明确的定义),不过多数情况下,你写你的MongoDB代码就像在PHP上编程一样。
4. 你不需要学习另外的语言
回忆一下其他你曾写过的数据库抽象层。回忆所有你曾使用过的ORM层。那么你现在可以抛弃他们的,在MongoDB上你用不着他们了。
MongoDB(包含它的PHP驱动)不需要询问语言。在大多数案例中,你只需要简单的给定一个指针具体制定你需要的,然后返回你一个文档指向。
如果你运行一些高阶函数(比如Map-Reduce),你可以通过JavaScript应用加入到MongoDB中去,并且在JavaScript内部引擎中运行这些脚本。
5. PHP和MongoDB是天生一对?
PHP已经对MongoDB具备很好的支持。Mongo驱动可以作为一个PECL加载项加入到PHP,这意味着安装起来就像运行PECL一样安装Mongo。
看到这里,你可以开始编写Mongo的API了。更广一些说,它和PDO排在一起。不是简单的消亡,但是绝对不同于我们之前开发过的数据库。
API的说明文档将包括一个引导和许多例子,这样你就可以在短时间内自举。下面将是对你十分有用的提示。
MongoDB发展非常快。
开发时间非常短,没有过多的模式来管理,很少(如果有的话)的数据映射。
因为没有新的查询语言要学习,代码的调整很小。毕竟,你不需要另外的ORM,封包也非常轻。
你的代码是未来的保证,可以更轻松的为你的对象增加更多的领域,甚至是更复杂的领域。因此你的代码可以很轻松的适应需求的变化。
延伸阅读
Mongo是一个高性能,开源,无模式的文档型数据库,它在许多场景下可用于替代传统的关系型数据库或键/值存储方式。Mongo使用C++开发,提供了以下功能:
面向集合的存储:适合存储对象及JSON形式的数据。
动态查询:Mongo支持丰富的查询表达式。查询指令使用JSON形式的标记,可轻易查询文档中内嵌的对象及数组。
完整的索引支持:包括文档内嵌对象及数组。Mongo的查询优化器会分析查询表达式,并生成一个高效的查询计划。
查询监视:Mongo包含一个监视工具用于分析数据库操作的性能。
复制及自动故障转移:Mongo数据库支持服务器之间的数据复制,支持主-从模式及服务器之间的相互复制。复制的主要目标是提供冗余及自动故障转移。
高效的传统存储方式:支持二进制数据及大型对象(如照片或图片)。
自动分片以支持云级别的伸缩性(处于早期alpha阶段):自动分片功能支持水平的数据库集群,可动态添加额外的机器。
MongoDB的主要目标是在键/值存储方式(提供了高性能和高度伸缩性)以及传统的RDBMS系统(丰富的功能)架起一座桥梁,集两者的优势于一身。根据官方网站的描述,Mongo适合用于以下场景:
网站数据:Mongo非常适合实时的插入,更新与查询,并具备网站实时数据存储所需的复制及高度伸缩性。
缓存:由于性能很高,Mongo也适合作为信息基础设施的缓存层。在系统重启之后,由Mongo搭建的持久化缓存层可以避免下层的数据源过载。
大尺寸,低价值的数据:使用传统的关系型数据库存储一些数据时可能会比较昂贵,在此之前,很多时候程序员往往会选择传统的文件进行存储。
高伸缩性的场景:Mongo非常适合由数十或数百台服务器组成的数据库。Mongo的路线图中已经包含对MapReduce引擎的内置支持。
用于对象及JSON数据的存储:Mongo的BSON数据格式非常适合文档化格式的存储及查询。
自然,MongoDB的使用也会有一些限制,例如它不适合:
高度事务性的系统:例如银行或会计系统。传统的关系型数据库目前还是更适用于需要大量原子性复杂事务的应用程序。
传统的商业智能应用:针对特定问题的BI数据库会对产生高度优化的查询方式。对于此类应用,数据仓库可能是更合适的选择。
需要SQL的问题。
MongoDB支持OS X、Linux及Windows等操作系统,并提供了Python,PHP,Ruby,Java及C++语言的驱动程序,社区中也提供了对Erlang及.NET等平台的驱动程序。
PHP 相关文章推荐
php面向对象全攻略 (三)特殊的引用“$this”的使用
Sep 30 PHP
php数组的一些常见操作汇总
Jul 17 PHP
PHP中判断变量为空的几种方法分享
Aug 26 PHP
php去除字符串换行符示例分享
Feb 13 PHP
ThinkPHP学习笔记(一)ThinkPHP部署
Jun 22 PHP
ThinkPHP连接数据库及主从数据库的设置教程
Aug 22 PHP
Zend Framework实现多文件上传功能实例
Mar 21 PHP
Laravel 5.3 学习笔记之 错误&日志
Aug 28 PHP
PHP laravel中的多对多关系实例详解
Jun 07 PHP
PHP使用GD库制作验证码的方法(点击验证码或看不清会刷新验证码)
Aug 15 PHP
PHP实现的简单对称加密与解密方法实例小结
Aug 28 PHP
php+mysql开发中的经验与常识小结
Mar 25 PHP
基于Discuz security.inc.php代码的深入分析
Jun 03 #PHP
基于HBase Thrift接口的一些使用问题及相关注意事项的详解
Jun 03 #PHP
基于php在各种web服务器的运行模式详解
Jun 03 #PHP
PHP运行模式的深入理解
Jun 03 #PHP
PHP代码保护--Zend Guard的使用详解
Jun 03 #PHP
ubuntu10.04配置 nginx+php-fpm模式的详解
Jun 03 #PHP
基于php-fpm的配置详解
Jun 03 #PHP
You might like
PHP简单字符串过滤方法示例
2016/09/04 PHP
javascript的事件描述
2006/09/08 Javascript
找到了一篇jQuery与Prototype并存的冲突的解决方法
2007/08/29 Javascript
Prototype RegExp对象 学习
2009/07/19 Javascript
Confirmer JQuery确认对话框组件
2010/06/09 Javascript
js面向对象 多种创建对象方法小结
2012/05/21 Javascript
jquery获取一组checkbox的值(实例代码)
2013/11/04 Javascript
JavaScript使用pop方法移除数组最后一个元素用法实例
2015/04/06 Javascript
jquery实现带缩略图的全屏图片画廊效果实例
2015/06/25 Javascript
jQuery Validate插件实现表单验证
2016/08/19 Javascript
那些精彩的JavaScript代码片段
2017/01/12 Javascript
JavaScript 值类型和引用类型的初次研究(推荐)
2017/07/19 Javascript
浅谈原型对象的常用开发模式
2017/07/22 Javascript
Node 自动化部署的方法
2017/10/17 Javascript
JavaScript实现异步图像上传功能
2018/07/12 Javascript
vue绑定事件后获取绑定事件中的this方法
2018/09/15 Javascript
详解Next.js页面渲染的优化方案
2019/01/27 Javascript
VUE中使用MUI方法
2019/02/12 Javascript
element-ui组件中input等的change事件中传递自定义参数
2019/05/22 Javascript
NodeJs生成sitemap站点地图的方法示例
2019/06/11 NodeJs
JS中的算法与数据结构之队列(Queue)实例详解
2019/08/20 Javascript
关于layui 弹出层一闪而过就消失的解决方法
2019/09/09 Javascript
ng-alain的sf如何自定义部件的流程
2020/06/12 Javascript
Python使用urllib模块的urlopen超时问题解决方法
2014/11/08 Python
python下载文件时显示下载进度的方法
2015/04/02 Python
python友情链接检查方法
2015/07/08 Python
浅谈python中requests模块导入的问题
2018/05/18 Python
解决pyecharts在jupyter notebook中使用报错问题
2020/04/23 Python
python判断无向图环是否存在的示例
2019/11/22 Python
HTML5 embed标签定义和用法详解
2014/05/09 HTML / CSS
美国高级工作服品牌:Carhartt
2018/01/25 全球购物
英国可持续奢侈品包包品牌:Elvis & Kresse
2018/08/05 全球购物
《特殊的葬礼》教学反思
2014/04/27 职场文书
党的群众路线整改落实情况汇报
2014/10/28 职场文书
让子弹飞观后感
2015/06/11 职场文书
python3实现常见的排序算法(示例代码)
2021/07/04 Python