Laravel Eloquent Union 查询

问题描述 投票:0回答:3

所以我有以下疑问:

$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 可能存在错误。

php mysql laravel eloquent laravel-5.3
3个回答
39
投票

尝试以下操作:

$a = Model::where('code', '=', $code)
->where('col_a', '=' , 1);

$b = Model::where('code', '=', $code)->where('col_b', '=' , 1)
->union($a)
->get();

$result = $b;

11
投票

尝试在

orderBy()
之后申请
union()

试试这个

$a->union($b)->orderBy(DB::raw('FIELD(layout, "normal", "split", "flip", "double-faced", "") ASC, layout'))->get();

编辑

研究并发现并准备了雄辩的查询,试试这个

$modelA = Model::where('code', '=', $code)
    ->where('col_a', '=' , 1)
    ->orderBy(DB::raw('FIELD(layout, "normal", "split", "flip", "double-faced", "") ASC, layout'))

$modelB = Model::where('code', '=', $code)
    ->where('col_b', '=' , 1)
    ->orderBy(DB::raw('FIELD(layout, "normal", "split", "flip", "double-faced", "") ASC, layout'))

$a = DB::table(DB::raw("({$modelA->toSql()}) as a"))
    ->mergeBindings($modelA->getQuery())
    ->selectRaw("a.*");

$b = DB::table(DB::raw("({$modelB->toSql()}) as b"))
    ->mergeBindings($modelB->getQuery())
    ->selectRaw("b.*");

$a->union($b)->get();

10
投票
Laravel 集合中的

“合并” 功能也许可以帮助你。 最大的区别是我提前用 ->get() 关闭查询,并且我使用 merge() 而不是 union()

$a = Model::where('code', '=', $code) ->where('col_a', '=' , 1) ->orderBy(DB::raw('FIELD(layout, "normal", "split", "flip", "double-faced", "") ASC, layout')) ->get(); $b = Model::where('code', '=', $code) ->where('col_b', '=' , 1) ->orderBy(DB::raw('FIELD(layout, "normal", "split", "flip", "double-faced", "") ASC, layout')) ->get(); $result = $a->merge($b);
注意:我没有你的数据,所以我无法证明它有效,但至少它对我的数据有效,所以值得你尝试

© www.soinside.com 2019 - 2024. All rights reserved.