MySQLに質問テーブル、質問TableGateway、およびQuestionFactoryモデルがあります。TableGateway が受け取った QuestionType に基づいて、TextQuestion()、BoolQuestion() などの別のクラスをインスタンス化したいと考えています。fetchall の状況では、これらの異なるクラスの結果セットが返されます。
これまでのところ、すべてがかなり標準的です。
'Application\Model\QuestionTable' => function($sm) {
$tableGateway = $sm->get('QuestionTableGateway');
$table = new \Application\Model\QuestionTable($tableGateway);
return $table;
},
'QuestionTableGateway' => function ($sm) {
$dbAdapter = $sm->get('Zend\Db\Adapter\Adapter');
$resultSetPrototype = new \Zend\Db\ResultSet\ResultSet();
$resultSetPrototype->setArrayObjectPrototype(new \Application\Model\QuestionFactory());
return new \Zend\Db\TableGateway\TableGateway('questions', $dbAdapter, null, $resultSetPrototype);
},
QuestionTableGateway は、以下を持つ TableGatewayBase を拡張します。
/**
* fetch all
* @return resultset
*/
public function fetchAll()
{
$resultSet = $this->tableGateway->select();
return $resultSet;
}
したがって、データベース内の QuestionType に基づいて別のクラスを返すように QuestionFactory を取得する必要があります。
Zend\Db\ResultSet をアプリケーション固有のバージョンで拡張し、 setArrayObjectPrototype() メソッドの実装が異なることを考えていました。
どんな助けでも大歓迎です。
アボー。