解决在laravel中leftjoin带条件查询没有返回右表为NULL的问题
吾爱主题
阅读:117
2021-09-03 15:24:00
评论:0
问题描述:在使用laravel的左联接查询的时候遇到一个问题,查询中带了右表一个筛选条件,导致结果没有返回右表为空的记录。
先附上代码:
?1 2 3 4 5 | DB::table( 'users as u' ) ->select( 'u.user_id' , 'c.class' ) ->leftJoin( 'class as c' , 'c.user_id' , '=' , 'u.user_id' ) ->where( 'c.status' , '=' ,2) ->get(); |
解决方案:
1.在mysql的角度上说,直接加where条件是不行的,会导致返回结果不返回class为空记录,正确是写法应该是
?1 | select u.user_id,c. class from users u left join class c on u.user_id=c.user_id and c.status=2; |
没错,正确写法是left join .. on .. and 而非 left join .. on .. where
2.那么,在laravel里这个mysql表达式的写法是怎样的,我查阅了多个手册。。。及国外网友求助问答,得到了以下答案
?1 2 3 4 5 6 7 8 | DB::table( 'users as u' ) ->select( 'u.user_id' , 'c.class' ) ->leftJoin( 'class as c' , function ( $join ) { $join ->on( 'c.user_id' , '=' , 'u.user_id' ) ->on( 'c.status' , '=' , '2' ); }) ->get(); |
希望能帮到大家!
以上这篇解决在laravel中leftjoin带条件查询没有返回右表为NULL的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持服务器之家。
原文链接:https://blog.csdn.net/php_girl/article/details/77478429
声明
1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。