laravel中Join语法以及使用Join多个条件

admin3年前PHP教程53

在laravel中我们常常会使用join,leftjion和rightjoin进行连表查询,非常的方便,但是我今天遇到一个问题,就是链表查询需要on多个条件,即我要订单的id和发货人都一样,默认的join只支持单个查询,所以我下面总结两种方法:

一、使用原是表达式(不推荐)

原生SQL中我们可以通过如下方法进行


select * from `orders` left join `users` on `orders`.`usename`=`users`.`usename` and `orders`.`platform`=`users`.`platform` where `orders`.`order_status` = 2

那么结合laravel,我们可以所以


DB::select('select * from `orders` left join `users` on `orders`.`usename`=`users`.`usename` and `orders`.`platform`=`users`.`platform` where `orders`.`order_status` = :id', ['id' => 1]);
二、使用高级的Join语法(推荐使用)

我们只需要所以如下代码即可完成我们的Join多个条件


DB::table('users')
 ->join('contacts', function ($join) {
  $join->on('users.id', '=','contacts.user_id')->on('users.usename', '=','contacts.usename');
  })
 ->get();

如果你想要了解更多,我们可以看一下文档中的描述:

让我们以传入一个闭包当作 join 方法的第二参数来作为开始。此闭包会接收 JoinClause 对象,让你可以在 join 子句上指定约束:


DB::table('users')
 ->join('contacts', function ($join) {
  $join->on('users.id', '=','contacts.user_id')->orOn(...);
  })
 ->get();

若你想要在连接中使用「where」风格的子句,则可以在连接中使用 where 和 orWhere 方法。这些方法会比较字段和一个值,来代替两个字段的比较:


DB::table('users')
  ->join('contacts', function ($join) {
   $join->on('users.id', '=', 'contacts.user_id')
     ->where('contacts.user_id', '>', 5);
  })
  ->get();

到此这篇关于laravel中Join语法以及使用Join多个条件的文章就介绍到这了,更多相关laravel中Join语法内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!

免责声明:本文内容来自用户上传并发布,站点仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。请核实广告和内容真实性,谨慎使用。

相关文章

php工程师工资是多少(前端吃香还是后端吃香)

php工程师工资是多少“月收入中位数*php程序工程师在全国的平均月薪为¥21,463,中位数为¥20,263,其中¥22k-30k工资占比最多,约17%。”前端吃香还是后端吃香不管是前端仍是后端,只...

PHP 生成器的使用详解

目录什么是生成器?生成器有什么用?生成器的应用返回空值以及中断返回键值对形式外部传递数据yield from 语法小惊喜生成器可以用count获取数量吗?使用生产器来获取斐波那契数列总结什么是生成器?...

PHP中最低级别的错误类型总结

序言:php错误就是会使脚本运行不正常的情况。php的错误有很多种,包括warning、notice、deprecated、fetal error等。其中notice不叫通知,而叫通知级别的错误,wa...

php两种基本的输出方法及实例详解

在 PHP 中,有两种基本的输出方法:echo 和 print。echo 和 print 之间的差异echo - 输出一个或多个字符串,可以接受多个参数并且没有返回值print - 只能输出一个字符串...

海外多IP服务器与海外站群服务器、海外seo服务器是什么关系

海外多IP服务器与海外站群服务器、海外seo服务器是什么关系?海外多IP服务器包含海外站群服务器和海外seo服务器。可以从以下几个方面论述。1.海外多IP服务器种类有哪些?从区域划分:目前市场上有美国...

php并发加锁问题分析与设计代码实例讲解

在工作项目中,会遇到一些php并发访问去修改一个数据问题,如果这个数据不加锁,就会造成数据的错误。下面我将分析一个财务支付锁的问题。希望对大家有所帮助。1 没有应用锁机制1.1 财务支付简化版本代码&...