【发布时间】:2017-06-05 00:21:08
【问题描述】:
所以我有以下查询:
$a = Model::where('code', '=', $code)
->where('col_a', '=' , 1)
->orderBy(DB::raw('FIELD(layout, "normal", "split", "flip", "double-faced", "") ASC, layout'))
$b = Model::where('code', '=', $code)
->where('col_b', '=' , 1)
->orderBy(DB::raw('FIELD(layout, "normal", "split", "flip", "double-faced", "") ASC, layout'))
$a->union($b)->get();
当我先 'orderBy()' 然后联合时,没有排序发生。
当我单独查询 '$a' 或 '$b' 时,'orderBy()' 工作正常。
当我按照以下方式执行时,'orderBy()' 会作为一个整体发生。
$a->union($b)
->orderBy(DB::raw('FIELD(layout, "normal", "split", "flip", "double-faced", "") ASC, layout'))
->get();
我怎样才能使'orderBy()'单独应用于每个,然后将结果合并回来?看来应该可以了。
编辑:如果有人可以提供一种方法来做到这一点,即使它是普通的 MySQL,我也会选择你的作为答案,因为我认为 Eloquent 可能存在错误。
【问题讨论】:
-
为什么它“不起作用”。错误或输出是什么
-
没有错误。它似乎没有应用 orderBy 排序。
-
这不是 Eloquent 的东西,而是 MySQL 的东西。请参阅此处接受的答案中的“跟进”:stackoverflow.com/questions/24683766/…。基本上:在 UNION 中 ORDER BY 将被忽略,甚至可能依赖于 MySQL 的版本。
标签: php mysql laravel eloquent laravel-5.3