[Laravel系列] 在Laravel ORM 使用STRAIGHT_JOIN
还是因为上一个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; }
十年开发经验程序员,离职全心创业中,历时三年开发出的产品《唯一客服系统》
一款基于Golang+Vue开发的在线客服系统,软件著作权编号:2021SR1462600。一套可私有化部署的网站在线客服系统,编译后的二进制文件可直接使用无需搭开发环境,下载zip解压即可,仅依赖MySQL数据库,是一个开箱即用的全渠道在线客服系统,致力于帮助广大开发者/公司快速部署整合私有化客服功能。
开源地址:唯一客服(开源学习版)
官网地址:唯一客服官网