主页 > 知识库 > 解决在laravel中leftjoin带条件查询没有返回右表为NULL的问题

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

热门标签:福泉电话机器人 天津营销电话机器人加盟代理 热线电话机器人 事业单位如何百度地图标注 南宁crm外呼系统平台 太原极信防封电销卡 格陵兰岛地图标注 地图标注入哪个科目 电销招聘机器人

问题描述:在使用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 join关联查询代码实例
  • 关于laravel 子查询 & join的使用
  • laravel高级的Join语法详解以及使用Join多个条件
  • Laravel 连接(Join)示例
  • laravel中Join语法以及使用Join多个条件

标签:阿克苏 香港 郴州 通化 佳木斯 自贡 金华 宝鸡

巨人网络通讯声明:本文标题《解决在laravel中leftjoin带条件查询没有返回右表为NULL的问题》,本文关键词  解决,在,laravel,中,leftjoin,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《解决在laravel中leftjoin带条件查询没有返回右表为NULL的问题》相关的同类信息!
  • 本页收集关于解决在laravel中leftjoin带条件查询没有返回右表为NULL的问题的相关信息资讯供网民参考!
  • 推荐文章