我不是在寻找$myRowset-> toArray();因为我想获得一个对象数组.
我想要做的是能够将$myRowset与对象数组合并.
$myOtherArray = [new Foo(), new Bar()];
$array = array_merge($myRowset, $myOtherArray);
使用Zend_Db_Table_Rowset,这是不可能的.使用$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_Table:
abstract class My_Db_Table extends Zend_Db_Table {
protected $_rowsetClass = 'My_RowSet';
}
现在我可以做:
$myRowset = $dbTable->fetchAll();
$rowArray = $myRowset->rowArray();
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。