您的位置:首页 > 教程 > PHP编程 > 解决在laravel中leftjoin带条件查询没有返回右表为NULL的问题

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

2020-09-04 08:14:14 来源:易采站长站 作者:

解决在laravel中leftjoin带条件查询没有返回右表为NULL的问题,写法,为空,正确,条件,多个

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

易采站长站,站长之家为您整理了解决在laravel中leftjoin带条件查询没有返回右表为NULL的问题的相关内容。

问题描述:在使用laravel的左联接查询的时候遇到一个问题,查询中带了右表一个筛选条件,导致结果没有返回右表为空的记录。

先附上代码:

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为空记录,正确是写法应该是

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表达式的写法是怎样的,我查阅了多个手册。。。及国外网友求助问答,得到了以下答案

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的问题的详细介绍。欢迎大家对解决在laravel中leftjoin带条件查询没有返回右表为NULL的问题内容提出宝贵意见

微信扫一扫

易采站长站微信账号