获取其作为数组的实现记录

时间:2017-02-26 13:58:18

标签: phalcon phalcon-orm

我有一个具有一对多关系的模型类。

class Budget extends Phalcon\Mvc\Model
{
    public function initialize()
    {
        $this->setSource('budgets');

        $this->hasMany('id', BudgetItem::class, 'budget_id');
    }
}

class BudgetItem extends Phalcon\Mvc\Model
{
    public function initialize()
    {
        $this->setSource('budget_items');

        $this->belongsTo('budget_id', Budget::class, 'id');
    }
}

因此,一个预算记录有许多budget_items。我想通过所有相关项目的ID来获取预算,因此我构建了一个查询:

$query = $modelsManager->createBuilder()
    ->addFrom(Budget::class, 'b')
    ->leftJoin(BudgetItem::class, 'b.id = bi.budget_id', 'bi')
    ->columns('b.*, bi.*')
    ->where('b.id = :id:', ['id' => 1])
    ->getQuery();

$result = $query->execute();

但结果对我来说看起来很奇怪。

{
    b: {
        id: "1"
    },
    bi: {
        id: "9",
        budget_id: "1",
        amount: "23500"
    }
},
{
    b: {
        id: "1"
    },
    bi: {
        id: "10",
        budget_id: "1",
        amount: "116500"
    }
}

而我期待的结果集看起来像这样:

{
    b: {
        id: "1"
        bi: [
            {
                id: "9",
                budget_id: "1",
                amount: "23500"
            }, {
                id: "10",
                budget_id: "1",
                amount: "116500"
            }
        ]
    }
}

有没有办法只获得一个包含两个项目数组的预算对象?

1 个答案:

答案 0 :(得分:0)

在您的示例中,您没有使用模型关系,而是使用具有正常左连接的查询构建器。这将始终返回多行。

如果您真的只需要1个预算及其所有budget_items,则可以使用上面定义的关系。

$budget = Budget::findFirst(22);
$budget->id; // id of your Budget table and other columns
$budget->budget_items; // This will contain array of all your budget_items relation