🔥码云GVP开源项目 12k star Uniapp+ElementUI 功能强大 支持多语言、二开方便! 广告
问题描述:在使用laravel的左联接查询的时候遇到一个问题,查询中带了右表一个筛选条件,导致结果没有返回右表为空的记录。 **先附上代码:** 代码语言:javascript 复制 ~~~javascript 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为空记录,正确是写法应该是 代码语言:javascript 复制 ~~~javascript 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表达式的写法是怎样的,我查阅了多个手册。。。及国外网友求助问答,得到了以下答案 代码语言:javascript 复制 ~~~javascript 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的问题就是小编分享给大家的全部内容了,希望能给大家一个参考。