您现在的位置是:网站首页> 编程资料编程资料
解决在laravel中leftjoin带条件查询没有返回右表为NULL的问题_php实例_
2023-05-25
291人已围观
简介 解决在laravel中leftjoin带条件查询没有返回右表为NULL的问题_php实例_
问题描述:在使用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的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
您可能感兴趣的文章:
相关内容
- 解决Laravel5.5下的toArray问题_php实例_
- laravel通过a标签从视图向控制器实现传值_php实例_
- laravel在中间件内生成参数并且传递到控制器中的2种姿势_php实例_
- laravel 实现划分admin和home 模块分组_php实例_
- laravel 根据不同组织加载不同视图的实现_php实例_
- Laravel 创建可以传递参数 Console服务的例子_php实例_
- laravel 自定义常量的两种方案_php实例_
- Laravel如何实现自动加载类_php实例_
- 解决laravel资源加载路径设置的问题_php实例_
- Laravel基础_关于view共享数据的示例讲解_php实例_
