只是想知道ZF2的水合结果集是否可以水合多个实体。考虑以下代码段:
$sql = new Sql($this->adapter);
$sqlObject = $sql->select()
->from([
'ART' => 'acl_roles'
])
->join([
'ARTT' => 'acl_role_types',
],
'ART.type_id = ARTT.id',
[
'ARTT.id' => 'id',
'ARTT.identifier' => 'identifier',
'ARTT.name' => 'name',
'ARTT.status' => 'status',
'ARTT.dateAdded' => 'date_added',
],
Select::JOIN_INNER
)
->where([
'ART.identifier' => $identifier,
])
->columns([
'ART.id' => 'id',
'ART.type_id' => 'type_id',
'ART.identifier' => 'identifier',
'ART.name' => 'name',
'ART.status' => 'status',
'ART.description' => 'description',
'ART.dateAdded' => 'date_added',
]);
现在,如果查询在单个实体上,则可以执行以下操作:
$stmt = $sql->prepareStatementForSqlObject($sqlObject);
$resultset = $stmt->execute();
if ($resultset instanceof ResultInterface && $resultset->isQueryResult()) {
$hydratingResultSet = new HydratingResultSet(new ArraySerializable, new EntityClass);
$hydratingResultSet->initialize($resultset);
return $hydratingResultSet->current();
}
但是,就我而言,我需要一个水合结果集,以便能够构建和返回多个实体(即AclRoleEntity和AclRoleTypeEntity)。这有可能吗?如果是,则如何(考虑结果集是两个实体的组合的平面数组)。如果没有,是否有更好的替代方法可以在不使用教义/推进的情况下实现?
谢谢
完全有可能,您只需要配置的(可能是自定义的)Hydrator。
您的水化器将需要了解将参数从平面数组注入到对象中的逻辑,以及如何在提取时将对象模型还原为平面数组。
您可能正在查看一些水合器策略或水合器命名策略,并且可能两者兼而有之。
使用正确的水化器,您可以实现所需的功能。
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句