Laravel Eloquent 特定列错误

Posted

技术标签:

【中文标题】Laravel Eloquent 特定列错误【英文标题】:Laravel Eloquent specific columns error 【发布时间】:2014-06-26 21:25:21 【问题描述】:

我在 Laravel 4.x 中使用 eloquent 有以下内容:

Book 表有十几个字段。

$single_data = Book::
            selectRaw("GROUP_CONCAT(DISTINCT CAST(id as char) SEPARATOR ',') as type_id_list")
            ->first();

问题:返回的数据是从 selectRaw 中看到的 Book AND type_id_list 内的表中的所有内容。

我只想返回我在 selectRaw 中指定的内容。

建议您在 first() 或 get() 中添加一个列数组,以便仅检索它 - 但是它不适用于您指定表达式或您自己的措辞的自定义 selectRaw。它会引发错误,并且在分析查询时,您首先放入/get 的数组将作为选择的一部分附加。

有人可以解决吗?

【问题讨论】:

first([]) 工作吗? @Andreas 啊,它也可以工作 - 但我会使用 pluck 代替,因为它会立即返回值本身而不是对象。 您可能应该将此报告为错误。 github.com/laravel/framework/issues @Andreas 是你先建议的 - 相信你。 first()first([]) 给出完全相同的结果,这是一个具有单个属性 type_id_listBook 模型(以及与查询无关的其他属性,例如 exists 等),因为 Eloquent提供 selectRaw 会忽略任何先前的选择。给定多个selectRaw 方法,它将只使用最后一个。 【参考方案1】:

first() 将只返回该特定列,但无论如何都包含在 Book 对象中,因此请改用 pluck()

$single_data = Book::
        selectRaw("GROUP_CONCAT(DISTINCT CAST(id as char) SEPARATOR ',') as type_id_list")
          ->pluck('type_id_list');

【讨论】:

注意:Andreas' comment first([]) 会产生正确的结果,但我需要做 ->type_id_list 来获取信息。

以上是关于Laravel Eloquent 特定列错误的主要内容,如果未能解决你的问题,请参考以下文章

Laravel - 使用 Eloquent 从连接关系模型中选择特定列

Laravel Eloquent - 从相关模型中检索特定列

在 Laravel Eloquent 中使用关系表中的特定列获取表中的特定列

如何通过分页获取 Laravel Eloquent 中的特定列?

在 Laravel Eloquent 中使用“With()”函数获取特定列

在 Laravel Eloquent 中获取 HasOne 关系中的特定列