-1

ルーメンで質問があります。しかし、うまくいきません。クエリは次のとおりです。

return Order::whereBetween('source_longitude', [$minLon_try_one, $maxLon_try_one])
        ->whereBetween('source_latitude',[51.365807806703,51.454384193297])
        ->where('status','=','pending')
        ->where('created_at','<=', 2016-04-07 12:00:35)
        ->where('created_at','>=', 2016-04-07 11:55:35)
        ->orWhere(function($query)
        {
                    $query->whereBetween('source_longitude', [51.321519613407, 51.498672386593])
                    ->whereBetween('source_latitude',[35.612195271526,35.756086728473])
                    ->where('status','=','pending')
                    ->where('created_at','<=',2016-04-07 11:55:35)
                    ->where('created_at','>=',2016-04-07 11:50:35);
        }
        )->get();

しかしorWhere、クエリから関数を削除すると、期待される結果が得られます

4

1 に答える 1

1

あなたはおそらくorWhere少し間違った使い方をしています。クエリを適切に実行するには、別の場所に場所を配置する必要があります。あなたが今していることはそのようなことですwhere a is 1 and b is 2 or (c is 3 and d is 4)が、私は信じています、あなたはそのようなことをしたいと思っていますwhere (a is 1 and b is 2) or (c is 3 and d is 4)

    return Order::where(function ($query) {
        $query->whereBetween('source_longitude', [$minLon_try_one, $maxLon_try_one])
            ->whereBetween('source_latitude', [51.365807806703, 51.454384193297])
            ->where('status', '=', 'pending')
            ->where('created_at', '<=', '2016-04-07 12:00:35')
            ->where('created_at', '>=', '2016-04-07 11:55:35');
    })->orWhere(function ($query) {
        $query->whereBetween('source_longitude', [51.321519613407, 51.498672386593])
            ->whereBetween('source_latitude', [35.612195271526, 35.756086728473])
            ->where('status', '=', 'pending')
            ->where('created_at', '<=', '2016-04-07 11:55:35')
            ->where('created_at', '>=', '2016-04-07 11:50:35');
    })->get();
于 2016-04-07T12:36:01.347 に答える