我在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;
}
所以我需要让QuestionFactory根据数据库中的QuestionType返回一个不同的类。
我正在考虑使用特定于应用程序的版本扩展Zend \ Db \ ResultSet,并使用不同的setArrayObjectPrototype()方法实现。
非常感谢任何帮助。
ABOR。
答案 0 :(得分:1)
我在zend 2中使用解决方案来解决您的问题。最有趣的是FabResiltSet类,它从AbstractResultSet和QuestionFab扩展而来,它将数组作为您要创建的类的映射。