gpt4 book ai didi

解决在laravel中leftjoin带条件查询没有返回右表为NULL的问题

转载 作者:qq735679552 更新时间:2022-09-29 22:32:09 28 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章解决在laravel中leftjoin带条件查询没有返回右表为NULL的问题由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

问题描述:在使用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 。

最后此篇关于解决在laravel中leftjoin带条件查询没有返回右表为NULL的问题的文章就讲到这里了,如果你想了解更多关于解决在laravel中leftjoin带条件查询没有返回右表为NULL的问题的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com