dongye7231
2017-05-23 10:37
浏览 314
已采纳

使用orwhere子句的Laravel eloquent orm查询

Hi I have been using this query to retrieve data based on orWhere clause

$q->where('created', $date);
$q->where(function ($query) {
  $query->where('gender', 'Male')
        ->where('age', '>=', 18);
})->orWhere(function($query) {
  $query->where('gender', 'Female')
        ->where('age', '>=', 30);   
})->orWhere(function($query) {
  $query->where('gender', 'Orthodox')
        ->where('age', '>=', 35);

first orWhere clause is working perfectly, however 2nd isnt. It seems to be a scope issue, i.e something with ()

图片转代码服务由CSDN问答提供 功能建议

您好我一直在使用此查询根据orWhere子句检索数据

  $ q-> where('created',$ date); 
 $ q-> where(function($ query){
 $ query-> where('gender','Male')  )
  - > where('age','> =',18); 
}) - > orWhere(函数($ query){
 $ query-> where('gender',' 女')
  - > where('age','> =',30); 
}) - > orWhere(函数($ query){
 $ query-> where('gender')  ,'正统')
  - > where('age','> =',35); 
   
 
 

first orWhere子句工作正常,但是 第二个不是。它似乎是一个范围问题,即带有() 的东西

  • 写回答
  • 好问题 提建议
  • 追加酬金
  • 关注问题
  • 收藏
  • 邀请回答

2条回答 默认 最新

  • doujimiao7480 2017-05-23 10:45
    已采纳

    Group your conditions properly and it should be fine.

    $q->where('created', $date);
    $q->where(function ($query) {
        $query->where(function ($query) {
            $query->where('gender', 'Male')
                ->where('age', '>=', 18);
        })->orWhere(function ($query) {
            $query->where('gender', 'Female')
                ->where('age', '>=', 30);
        })->orWhere(function ($query) {
            $query->where('gender', 'Orthodox')
                ->where('age', '>=', 35);
        });
    });
    
    评论
    解决 无用
    打赏 举报
  • 查看更多回答(1条)

相关推荐 更多相似问题