【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();
相关推荐
爱码小白9 分钟前
MySQL 常用数据类型的系统总结
数据库·python·算法
被摘下的星星9 分钟前
MySQL drop和delete的区别
数据库·mysql
攻城狮7号17 分钟前
面向未来的时序数据库选型指南:当数据存储遇上原生AI
数据库·人工智能·时序数据库·apache iotdb
wb18917 分钟前
企业级MySQL重习
数据库·笔记·mysql·adb·云计算
移动云开发者联盟21 分钟前
告别AI失忆!移动云大云海山数据库解锁OpenClaw云端长期记忆
数据库·人工智能
YOU OU26 分钟前
MySQL面试题
sql·mysql
软件开发技术29 分钟前
最新电子商务购物商城系统源码 三端_H5+微信+安卓
微信·php
野生技术架构师38 分钟前
一个简单SQL的深度解析
android·数据库·sql
麦聪聊数据43 分钟前
数据库安全与运维管控(五):基于AST的SQL拦截与动态审批
运维·数据库·sql
BullSmall44 分钟前
linux 系统下模拟网络丢失和ping延迟,可以怎么来模拟
linux·网络·php