首页 >后端开发 >php教程 >php面向对象进阶设计模式:数据访问对象模式

php面向对象进阶设计模式:数据访问对象模式

巴扎黑
巴扎黑原创
2017-05-22 09:48:581560浏览

什么是数据访问对象模式?

数据访问对象设计模式描述了如何创建提供透明访问任何数据的对象。

数据访问对象模式应用问题与解决方案

对于同时学过PHP和MySQL的人来说,数据访问对象设计模式是一个全新的和令人兴奋的概念。这种设计模式的目的是解决下列两种特定的问题:重复与数据源抽象化。

我们应当创建一个数据访问对象设计模式的对象。这个数据访问对象封装了创建sQL调用、减少实例创建的复杂性和重复以及更新进程的智能方式,其编写方式应当是:该对象的使用者不会知道实际使用的表结构和数据库引擎。此外,这个对象应用的方法应当使用逻辑参数,并且应处理SQL语句的创建工作。

        数据访问对象模式的额外优点是提供数据库抽象层。现在,应用程序的主要处理代码不再需要考虑数据库引擎或表关系。调用这种对象的公共方法会返回任何数据类型,并且不用考虑内在SQL需要的类型。

 管理数据访问对象类中简单性的一个好办法是创建父-子关系。首先,创建一个基本的父对象。这个对象应当负责数据库连接、抽象地执行查询以及与子对象通信。使用数据访问对象设计模式时,最好开始就将一对一关系的子类与数据库中的表相关联。这些子类具有必不可少的信息,如表名和主键。此外,子类可能包含一些特定的公共方法,这些方法通过只对子类有意义的方式执行父类的查询。例如,名为userAddress的子类可能包含一个getAddreddesByZip()方法。将该方法放入父DAO类是毫无逻辑意义的,并且会破坏这个父类希望实现的抽象性。

        处理引用特定数据库信息的实体时,最好的做法是创建一个数据访问对象。

<?php 
//数据访问对象模式 
 
//将数据库访问层脱离出来 作为公用的访问接口,方便用户开放,是php中常用的一种设计模式 
 
class BaseDao { 
    private $db; 
     
    public function __construct($config) {  
        $this->db = mysql_connect($config[&#39;user&#39;], $config[&#39;pass&#39;], $config[&#39;host&#39;]); 
        mysql_select_db($config[&#39;database&#39;], $this->db); 
    } 
     
    public function query($sql) { 
        return mysql_query($sql, $this->db); 
    } 
}

代码:UserDao 用户数据表的数据操作,继承BaseDao

<?php 
include("UserDao.php"); 
class UserDao extends BaseDao { 
    public function addUser() { 
        $sql = "INSERT INTO user (username) VALUES (&#39;initphp&#39;)"; 
        return $this->query($sql); 
    } 
} 
 
$UserDao = new UserDao; 
$UserDao->addUser();

以上是php面向对象进阶设计模式:数据访问对象模式的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn