【PHP】where和whereOr一起复杂查询示例

在ThinkPHP 5 中,wherewhereOr 方法可以一起使用以实现复杂的查询条件。以下是一个示例:

php 复制代码
// 接收的参数
$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();
相关推荐
wljt19 小时前
Redis的5种数据类型
数据库·redis·缓存
sakiko_19 小时前
Swift学习笔记30-数据库SQlite语句
数据库·学习·swift
IvorySQL19 小时前
用生成列提升 JSONB 查询效率:PostgreSQL 三种索引方案实测对比
数据库·postgresql
STDD19 小时前
Abiotic Factor多人生存建筑游戏《非生物因素》 专用服务器搭建教程
服务器·数据库·游戏
淼淼爱喝水19 小时前
【Ansible 入门实战】三种变量详解
java·linux·数据库·ansible·playbook
云草桑19 小时前
Odoo企业商用到底是不是免费的?
数据库·odoo·erp
燕-孑20 小时前
redis详解-进阶
数据库·redis·缓存
BGD1045017320 小时前
datagear(7)-期末作业:综合数据分析
数据库·数据分析
Hoxy.R20 小时前
百家争鸣下的 Vastbase G100:一次国产数据库体验与思考
数据库
雪度娃娃20 小时前
Asio异步读写——简单服务器和客户端异步通信
运维·服务器·网络·c++·php