首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >[Laravel系列] 在Laravel ORM 使用STRAIGHT_JOIN

[Laravel系列] 在Laravel ORM 使用STRAIGHT_JOIN

作者头像
唯一Chat
发布2021-10-29 11:09:11
发布2021-10-29 11:09:11
1.3K0
举报
文章被收录于专栏:陶士涵的菜地陶士涵的菜地

还是因为上一个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]);

代码语言:javascript
复制
    /**
     * 格式化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;
    }
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021-10-27 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档