今天要做查询功能,有的关键词为空,有的有值,
实现原理如下:
$handle = DB::table(‘classrooms‘);
// 如果条件1为真的时候
$keywords1 && $handle->where(‘field_name‘,‘like‘,‘%‘ . $keywords1 . ‘%‘);
// 如果条件2为真的时候
$keywords2 && $handle->where(‘field_name‘,‘like‘,‘%‘ . $keywords2 . ‘%‘);
// 如果条件3为真的时候
...
// 获取数据
$handle->get();
代码可以精简如下:
$handle = DB::table(‘classrooms‘);
$keys = $request->all();
foreach($keys as $key => $val){
$keys[$key] && $handle->where($key,‘like‘,‘%‘ . $val . ‘%‘);
}
// 获取数据
$datas = $handle->get();
摘自:https://segmentfault.com/q/1010000007556256?_ea=1386542