php平台开源orm库doctrine应用

php平台开源orm库doctrine应用

ID:5597667

大小:27.50 KB

页数:5页

时间:2017-12-19

php平台开源orm库doctrine应用_第1页
php平台开源orm库doctrine应用_第2页
php平台开源orm库doctrine应用_第3页
php平台开源orm库doctrine应用_第4页
php平台开源orm库doctrine应用_第5页
资源描述:

《php平台开源orm库doctrine应用》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库

1、PHP平台开源ORM库Doctrine应用  摘要:研究了传统数据库访问技术的缺点、ORM技术的原理和优点,以及PHP平台的ORM实现库Doctrine的技术要点,最后介绍了Doctrine技术在项目中的实际应用效果。关键词关键词:开源数据库;PHP;ORM;Doctrine中图分类号:TP311文献标识码:A文章编号:16727800(2014)0020102030引言在现代信息系统开发过程中,关系数据库的访问是最基本、最繁琐的一部分。传统的开发方式是直接在程序代码中嵌入SQL语句,用于操作数据库[1]。这个过程不是面向

2、对象的,所有数据相对于系统来说,只是一些原始数据,与业务实体没有明显的对应关系。另外,不同数据库系统往往支持不同的SQL方言[2],针对某种数据库系统(如mysql)开发的软件,如果想迁移到另一种数据库系统(如sqlserver),需要做大量的SQL方言移植工作。一个稍微复杂一点的系统往往包含成百上千个数据表,采用传5统的方式开发,数据库访问的工作量非常大。为了提高软件开发效率,避免开发人员编写大量的SQL语句,将数据封装成面向对象的业务实体,使之更具现实含义。封装数据库访问功能,屏蔽不同数据库方言对软件开发的影响,便于不

3、同数据库系统迁移,ORM技术应运而生。1ORM原理信息系统开发工具可以归纳为两类:数据库管理系统(主要是关系数据库系统,如Oracle、SqlServer、MySql等)和编程语言(主要是面向对象的编程语言,如java、C#、PHP5等)。这两类数据维护方法是完全不同的。关系数据库是建立在关系模型理论基础上的数据库[3],是包含进入预先定义的种类之内的一组表格。每个表格(有时被称为一个关系)包含用列表示的一个或更多的数据种类。每行包含一个唯一的数据实体,这些数据是被列定义的种类。应用程序操作关系数据库的接口是结构化查询语言

4、(SQL)。面向对象的编程语言是当前程序设计的主流语言,其主要思想是将“对象”共有的属性和行为“封装”成一个“类”,从而达到软件工程的三个主要目标:重用性、灵活性、扩展性[4]。当关系模型和面向对象的编程语言结合在一起时,就会产生不匹配的麻烦。这是因为它们基于完全不同的视角,一个是用于存储和维护大量数据,另一个是用于实现处理这些数据的算法[5]。程序员需要使用SQL语句从数据库中检索数据或将数据保存到数据库中,因此必须对数据库结构了如指掌。ORM(ObjectRelational5Mapper)技术正是用来解决这个不匹配的

5、问题,它充当了编程语言和关系数据库之间的桥梁,程序员无需考虑数据库是如何存储、检索和维护的,可以将工作重心置于应用程序逻辑处理本身。所有的ORM框架都是将一个数据表映射成一个实体类,字段映射为实体类的属性,记录映射为一个实体对象,表之间的外键引用则映射对象关联[6]。ORM框架自动根据映射信息生成对应的SQL访问数据库。2Doctrine技术目前,基于PHP平台的ORM方案并不多,已知的有Doctrine,Propel,EZPDO,RedBean,ZendDb,ActiveRecord,Outlet等。经过比较,Doctr

6、ine是其中最为成熟的一个[7]。Doctrine基于强大的DBAL(数据库抽象层),其中一个最主要的功能就是使用面向对象的方式执行数据库查询。受HibernateHQL的影响,Doctrine使用一种叫DQL的查询语句进行数据库查询。它可以通过PHP对象轻松访问所有数据库[8]。Doctrine由两个项目组成,一个是DatabaseAbstraction5Layer,它是一个强大的数据库抽象层,提供对PDO的封装,用于对特定数据库无关的数据访问。PDO本身主要包含两个类:PDO和PDOStatement。DBAL中对应的

7、接口是Doctrine\\DBAL\\Connection和Doctrine\\DBAL\\Satement,由具体的数据库驱动实现,从而实现数据库的无依赖性[8]。4结语Doctrine是PHP平台成熟的ORM技术,它使用面向对象的思想操作数据库,极大地减轻了开发人员的工作量,提高了系统设计与开发的效率,增强了系统的稳定性、可维护性以及数据库平台的可移植性。参考文献:[1]吴卫平,王丽芳,蒋泽军.基于ORM的数据持久层框架研究[J].微电子学与计算机,2008,25(7):188190.[2]克兰,克兰,亨特.SQL技术

8、手册[M].北京:电子工业出版社,2009:1112.[3]DavidMKroenke,DavidJAuer.数据库原理[M].北京:清华大学出版社,2011:67.[4]列旭松,陈文.PHP核心技术与最佳实践[M].北京:机械工业出版社,2012:12.[5]DragosPaulPop.Designi

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。