在ThinkPHP 5 中,where
?和?whereOr
?方法可以一起使用以实现复杂的查询条件。以下是一个示例:
// 接收的参数
$param = $this->request->param();
// 实例化
$query = new UserModel();
// 关联表
$query->with(['collect' => function($collect_query) use ($user_id) {
$collect_query->field('id,user_id');
$collect_query->where('user_id', user_id);
}]);
// 查询条件
$query->where(['status' => 1])
// 可筛选逗号分割的
$query->where("FIND_IN_SET({$user_id},parent_ids)")
// 价格区间最小值
if(isset($param['min_money']) && is_numeric($param['min_money'])){
$query->where(function ($query) use ($param) {
$query->where('price_min', '>=', $param['min_money'])->orWhere('price_max', '>=', $param['min_money']);
});
}
// 价格区间最大值
if(isset($param['max_money']) && is_numeric($param['max_money'])){
$query->where(function ($query) use ($param) {
$query->where('price_min', '<', $param['max_money'])->orWhere('price_max', '<', $param['max_money']);
});
}
// 查询结果
$list = $query->field(TaskModel::HALLLIST)
->order($sort)
->select();