编程语言
首页 > 编程语言> > PHP-Zend_Db_Table_Rowset到对象数组

PHP-Zend_Db_Table_Rowset到对象数组

作者:互联网

我不是在寻找$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();

标签:zend-db,zend-db-table,arrays,zend-framework,php
来源: https://codeday.me/bug/20191201/2078651.html