我不寻找$myRowset->toArray();
,因为我想得到一个对象数组。
我想做的是能够将$myRowset
与一个对象数组合并。
$myOtherArray = [new Foo(), new Bar()];
$array = array_merge($myRowset, $myOtherArray);
对于zend_db_table_行集,这是不可能的。使用
$myRowset->toArray();
也不起作用,因为我需要一个对象数组。编辑-代码执行我所需操作的示例,但我正在寻找更好的解决方案(如果存在):
// Convert the Zend_Db_Table_Rowset to an array of Zend_Db_Table_Row
$myRowset = $dbTable->fetchAll();
$rowArray = array();
foreach ($myRowset as $row) {
$rowArray[] = $row;
}
// Merge with other array of objects
$myOtherArray = [new Foo(), new Bar()];
$finalArray = array_merge($rowArray, $myOtherArray);
最佳答案
这是我的“最干净”解决方案:我重写zend_db_table_rowset
class My_RowSet extends Zend_Db_Table_Rowset {
public function rowArray() {
$rowArray = array();
foreach ($this as $row) {
$rowArray[] = $row;
}
return $rowArray;
}
}
和zend_db_表:
abstract class My_Db_Table extends Zend_Db_Table {
protected $_rowsetClass = 'My_RowSet';
}
现在我可以:
$myRowset = $dbTable->fetchAll();
$rowArray = $myRowset->rowArray();