有没有更好的方法与ZF期运用映射器,现实生活中的对象和table_objects工作。

这是我与Zend框架做到这一点:

class User_DbTable extends Zend_DB_Table_Abstract{
      protected $_name = "user"; // name of the table
}

用户类 - >用户对象:

class User{
  protected $_id;
  protected $_name;
  protected $_addresses; //list of OBJs

  public function set_name($_name){
    $this->_name = $_name;
  }
  public function get_name(){
    return $this->_name;
  }
  public function set_adresses($_addresses){
    $this->_addresses = $_addresses;
  }
// and so on....
}

映射器:

class UserMapper{
   protected $userTBL;

   public function __construct(){
     $this->userTBL = new User_DbTable();
   }
   public function __fatchAll(){
     $select = $this->userTBL->select();
     foreach($this->userTBL->fetchAll($select) as $row){
       $user = new User(); // model
       $user->set_name($row->name);
       // gat all the addreses of this user with eg. AddressMapper()
       $user->set_addresses($addresses); // array of object of address just like User
       $users[] = $user;
     }
     return $users;
   }
}

使用在控制器: 列表动作:

$userMP = new UserMapper();
$this->view->users = $userMP->__fatchAll();

或添加/保存动作:

$newUser = new User();
$newUser->set_name('somename');
$userMP = new UserMapper();
$userMP->save($newUser);
有帮助吗?

解决方案

ZF让你延长Zend_Db_Table_Row类,并告诉你的类的Zend_Db_Table总是使用它。通过这种方式,您可以访问所有的Zend_Db_Table_Row功能,同时在上面添加自己的逻辑。

您可以是这样做的。

class User_DbTable extends Zend_DB_Table_Abstract{
      protected $_name = "user"; // name of the table
      protected $_rowClass = "User"; // The name of your Zend_Db_Table_Row class
}

class User extends Zend_Db_Table_Row {

  public function set_name($_name){
    $this->name = $_name;
  }
  public function get_name(){
    return $this->name;
  }
  public function set_adresses($_addresses){
    $this->addresses = $_addresses;
  }
// and so on....
}

您可以看到更多的Zend_Db_Table_Row 这里

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top