解决在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为空记录,正确是写法应该是多表left join
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的问题就是⼩编分享给⼤家的全部内容了,希望能给⼤家⼀个参考,也希望⼤家多多⽀持。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论