doujie4344 2017-02-25 18:17
浏览 172
已采纳

Laravel数据库查询返回空集合

I have a small table and try to use some filters to get some specific data out of it.

My attempt:

$matchingCars = Car::where([
    ['brand', '=', request('brand')],
    ['model', '=', request('model')],
    ['price', '<', request('maxPrice')],
])->get();

Result:

Collection {#249 ▼
  #items: []
}

You can see nothing is returned. However, if I do the queries one by one and count the result, then I get a number higher than 0, so there are models who pass my filters!

    $checkBrands = Car::where('brand', '=', request('brand'))->get(); 
    $checkModels = Car::where('model', '=', request('model'))->get(); 
    $checkPrice  = Car::where('price', '<', request('maxPrice'))->get(); 

    echo count($checkBrands) . "<br>";   //output: 1
    echo count($checkModels). "<br>";    //output: 1
    echo count($checkPrice). "<br>";     //output: 8
    die;

Why are they not stored in the collection?

  • 写回答

3条回答 默认 最新

  • drbae3964 2017-02-25 18:23
    关注

    You need to orWhere():-

    $matchingCars = Car::where('brand', '=', request('brand'))
                       ->orwhere('model', '=', request('model'))
                       ->orwhere('price', '<', request('maxPrice'))->get()
    

    Note:-

    you said:- However, if I do the queries one by one and count the result, then I get a number higher than 0

    But this doesn't mean that combination of all these three queries with AND will return result.

    So apply OR condition like above.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 安装svn网络有问题怎么办
  • ¥15 Python爬取指定微博话题下的内容,保存为txt
  • ¥15 vue2登录调用后端接口如何实现
  • ¥65 永磁型步进电机PID算法
  • ¥15 sqlite 附加(attach database)加密数据库时,返回26是什么原因呢?
  • ¥88 找成都本地经验丰富懂小程序开发的技术大咖
  • ¥15 如何处理复杂数据表格的除法运算
  • ¥15 如何用stc8h1k08的片子做485数据透传的功能?(关键词-串口)
  • ¥15 有兄弟姐妹会用word插图功能制作类似citespace的图片吗?
  • ¥15 latex怎么处理论文引理引用参考文献