Класс-таблица-маппер дизайн php и zf
Есть ли лучший способ для работы с ZF, используя мапперы, реальные объекты и table_objects.
Вот как я делаю это с Zend Framework:
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);
1 ответ
Решение
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
Вот