[Laravel系列] 在Laravel ORM 使用STRAIGHT_JOIN

没有检索到摘要

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

还是因为上一个join优化的问题,项目使用laravel框架

但是框架自身的join()方法并不能使用  STRAIGHT_JOIN 

stackoverflow 同名问题,查到的方法

mysql - Is there a way to create a STRAIGHT_JOIN using Laravel's ORM? - Stack Overflow

在组合字段数组的时候,在第一个字段上增加  straight_join 字段

试下这样的语句  select  straight_join 字段,  字段二, 字段三 等

重点是这句

 $field[0] = \DB::raw('straight_join '.$field[0]);

    /**
     * 格式化field
     * @param array $field
     * @return array
     */
    private function buildField(array $field): array
    {
        // 若查询id 则 获取的是主表的id
        if (in_array('id', $field)) {
            $field[array_search('id', $field)] = 'mumway_recruit_student.id';
        } else if($field == ['*']) {
            $field = [
                    'mumway_recruit_student.*',
                    'mumway_recruit_work_train.clue_id',
                    'mumway_recruit_work_train.clue_status',
                    'mumway_recruit_work_train.communicate_role',
                    'mumway_recruit_work_train.is_active_release_privacy',
                    'mumway_recruit_work_train.intention_worker_type',
                    'mumway_recruit_work_train.worker_type',
                    'mumway_recruit_work_train.train_status',
                    'mumway_recruit_work_train.follow_user_id',
                    'mumway_recruit_work_train.follow_user_name',
                    'mumway_recruit_work_train.professional_follow_user_id',
                    'mumway_recruit_work_train.professional_follow_user_name',
                    'mumway_recruit_work_train.city_code',
                    'mumway_recruit_work_train.city_name',
                    'mumway_recruit_work_train.group_id',
                    'mumway_recruit_work_train.auth_id',
                ];
        }
        $field[0] = \DB::raw('straight_join '.$field[0]);
        return $field;
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值