在Lumen中修复Mongo查询

时间:2016-04-07 12:22:34

标签: mongodb laravel lumen jenssegers-mongodb

我在流明中有一个查询。但它不起作用。查询是:

@Autowired
private GetStudentDetail getStudentDetail;

getStudentDetail.getStudentDetails(String rollNo);

但是当我从查询中删除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(); 函数时,我得到了预期的结果

1 个答案:

答案 0 :(得分: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();