thinkphp通过with查询,并通过关联表进行筛选

直接添加一个where条件,然后条件里面用表名.字段即可,非常方便
需要注意的一点是在fastadmin里面,$this->auth->getGroupIds()这样获取是会获取到缓存里面的值,必须重新登录之后才可以得到最新的用户组,这个问题导致困扰了我一晚上

php 复制代码
 $usage = $this->model
                ->with(['user', 'device', 'devicetype']);
            if (in_array(3, $this->auth->getGroupIds()) || in_array(5, $this->auth->getGroupIds())) {
                //用户角色为业务员或者销售经理时,只显示所在区域的设备
                $usage->where('user.area_id', 'in', $this->auth->area_ids);
            }
            $list = $usage
                ->where($where)
                ->order($sort, $order)
                ->paginate($limit);

上面这些在后台管理系统里面是有作用的,但是前端的api接口确没起到效果,不知为何

前端api我使用join查询,添加条件

with查询的原理:其实是主查询查询出数据只是,再把查出的所有的xxx_id都拿出来,单独用in查询查询出一个列表,然后把主查询得到的列表与with得到的列表直接合并,所以with不会影响主查询,主查询该怎么查还是怎么查就行了

php 复制代码
$list = \app\common\model\Materialrecord:: alias('r')
            ->with('material')
            ->join('materials m', 'r.material_id = m.id')
            ->where('r.batch_id', $batch_id)
            ->order('r.addtime desc')
            ->select();
相关推荐
hbh112233abc10 天前
实现 think/queue 日志分离
php·thinkphp·queue
tekin22 天前
vscode通过.vscode/launch.json 内置php服务启动thinkphp 应用后无法加载路由解决方法
vscode·json·php·路由·thinkphp·内置服务
hanzhuhuaa24 天前
thinkphp和vue基于Workerman搭建Websocket服务实现用户实时聊天,完整前后端源码demo及数据表sql
websocket·即时通讯·thinkphp·实时聊天·vue聊天
appleคิดถึง1 个月前
fastadmin 列表页表格实现动态列
android·fastadmin·tp5
A_ugust__1 个月前
vue3.2实现AES加密解密,秘钥通过API获取,并混淆秘钥,后端thinkphp
vue·aes·thinkphp
appleคิดถึง1 个月前
fastadmin 多商户模式下侧边栏跳转路径BUG
fastadmin·多商户
向宇it2 个月前
fastadmin搜索刷新列表,怎么限制用户频繁点击?
开发语言·前端·javascript·fastadmin
A864452 个月前
解决在Nignx下Thinkphp路由不生效问题
开发语言·nginx·php·thinkphp
2407-2 shw2 个月前
Thinkphp5x远程命令执行 靶场攻略
php·thinkphp
向宇it2 个月前
FastAdmin列表用echats渲染,使用表格的templateView实现一个图表渲染的功能
php·web·fastadmin