class-tavolo-mapper progettazione php e ZF
-
19-09-2019 - |
Domanda
c'è un modo migliore di lavorare con ZF useing i mapper, oggetti della vita reale e table_objects.
Questo è come lo faccio con Zend Framework:
class User_DbTable extends Zend_DB_Table_Abstract{
protected $_name = "user"; // name of the table
}
la classe utente -> oggetto utente:
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....
}
il mapper:
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;
}
}
Utilizzo controller: elenco di azioni:
$userMP = new UserMapper();
$this->view->users = $userMP->__fatchAll();
o aggiungere / salvataggio di azione:
$newUser = new User();
$newUser->set_name('somename');
$userMP = new UserMapper();
$userMP->save($newUser);
Soluzione
ZF permette di estendere la classe Zend_Db_Table_Row
, e dire la vostra classe Zend_Db_Table utilizzare sempre esso. In questo modo, è possibile accedere a tutte le funzioni Zend_Db_Table_Row
, nell'inserire la tua propria logica in alto.
Si può fare in questo modo
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....
}
Si può vedere di più sul Zend_Db_Table_Row
qui
Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a StackOverflow