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_list
的 Book
模型(以及与查询无关的其他属性,例如 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 中的特定列?