如果我有一个包含groupBy的查询:

Table::select('a','b','c','d')->groupBy('a','b','c','d')->get();

如何提取每个组中的唯一值?

例如,如果返回的数据集为:

Row1 = a1, b1, c1, d1
Row2 = a1, b1, c1, d2
Row3 = a2, b2, c2, d3
Row4 = a2, null, c3, d4

然后,我想提取唯一列:

$col_a = [a1, a2]

$col_b = [b1, b2, null]

$col_c = [c1, c2, c3]

$col_d = [d1, d2, d3 ,d4]

推荐答案

Okay so now as I understand your issue, please see the following solution:在这种情况下,您不需要使用DISTINCT,因为分组可以解决问题.

//Option 1 - Select only what you need
$query = Table::select('a', 'b', 'c', 'd')->get();

//Option 2 - if you need more data later
$query = Table::all();
        
$col_a = array_keys($query->groupby('a')->toArray());
$col_b = array_keys($query->groupby('b')->toArray());
$col_c = array_keys($query->groupby('c')->toArray());
$col_d = array_keys($query->groupby('d')->toArray());

Results:

$col_a = [a1, a2]
$col_b = [b1, b2, '']
$col_c = [c1, c2, c3]
$col_d = [d1, d2, d3 ,d4]

Group By::

MySQL GROUP BY条声明 将具有相同值的行分组成汇总行,如"查找每个国家/地区的客户数量".https://www.w3schools.com/mysql/mysql_groupby.asp

Laravel相关问答推荐

当使用Craftable PRO时,Wysiwig是什么时候生成的?

自定义验证在表单请求上始终返回 true laravel

无法找到用户sail:passwd 文件中没有匹配的条目

Laravel Livewire 组件在刷新后不会自动刷新/重新加载

判断 Laravel 中是否存在唯一索引键

判断 Laravel 模型表中是否存在列,然后应用条件

路由中间的可选参数

设置 Laravel 5.4 以使用 React

SQLSTATE [01000]:警告:1265 列的数据被截断(truncated)

Laravel - 自定义时间戳列名称

如何在 Laravel Eloquent 中 Select 某些字段?

如何在 Laravel 5 中验证当前、新密码和新密码确认?

Laravel 控制器构造

laravel 4:更新行时如何从列的当前值中减一?

Laravel:自定义或扩展通知 - 数据库模型

在 Laravel 应用程序中在哪里指定应用程序版本?

Laravel 5.3 通知 - 仅使用Electron邮件地址通知

如何在 Laravel 中使用补丁请求?

Laravel 5 - 跳过迁移

如何使用队列设置高、低和中优先级Electron邮件?