您的位置:首页 > 编程学习 > > 正文

laravel测试重连数据库(解决在laravel中leftjoin带条件查询没有返回右表为NULL的问题)

更多 时间:2021-10-01 01:09:44 类别:编程学习 浏览量:1352

laravel测试重连数据库

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

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

先附上代码:

  • ?
  • 1
  • 2
  • 3
  • 4
  • 5
  • 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为空记录,正确是写法应该是

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

  • ?
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 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的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持开心学习网。

    原文链接:https://blog.csdn.net/php_girl/article/details/77478429

    您可能感兴趣