orWhere如果不用閉包的形式寫很容易寫成分開的查詢條件
要寫成一組查詢條件需要這樣閉包寫(就相當於把這兩個條件放在一個小括號里,是一組查詢條件“(xxx or xxx)”):
if (!empty($key)) {
$goodsModel = $goodsModel->where(function ($query) use ($key) {
$query->where('a', 'like', "%{$key}%")->orWhere('b', 'like', "%{$key}%");
});
}
$goodsShow = Goods::where('cate_id','=',$cate_id) ->where(function($query){ $query->where('status','<','61') ->orWhere(function($query){ $query->where('status', '91'); }); })->first();
這一段其實執行的就是where cate_id = $cate_id AND (status < 61 OR status = 91)