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

admin3年前PHP教程36

在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语法内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!

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

相关文章

济南高防服务器防护软件有哪些

济南高防服务器防护软件有哪些?济南高防服务器防护软件有很多,以下是一些常见的高防服务器防护软件:防火墙软件:如iptables、firewalld等,可以限制服务器的端口开放和流量控制,防止黑客入侵。...

再谈PHP未来之路

这门语言现在到底处于生命周期的哪个阶段?其定位到底是怎样的?诸如 PHP7、Swoole 的出现到底能给 PHP 带来怎样的变化?当我们拿 PHP 和 java 进行比较的时候,我们往往就两门语言本身...

购买海外多ip服务器的好处有哪些

购买海外多ip服务器的好处有:1、不用备案,能即买即用,非常方便;2、访问速度快,能有效保证海外目标用户所在地区的速度;3、网络带宽资源充足,能满足网站的不同需求;4、对网站内容管理宽松,有利于网站多...

PHP时间类完整代码实例

开发中,经常用到时间的一些例子,比如昨天,今天,前天,近七天,一周等等。这里整理了一个时间的完整类实例,直接实例化,有需要的可以看看以下直接代码<?phpheader("Content...

海外多ip服务器被恶意攻击了怎么办

海外多ip服务器被恶意攻击的解决方法:1、对网站攻击进行评估,根据具体的攻击进行具体的防御;2、建立镜像网站,将网站的客户引到镜像网站中去;3、建立预防DDoS策略,并定期对服务器进行查毒杀毒,能降低...

扬州高防服务器租用如何保障其稳定性

扬州高防服务器租用如何保障其稳定性?扬州高防服务器的稳定性需要从多个方面进行保障:1.硬件设施:扬州高防服务器租用服务提供商应确保其服务器硬件设施的质量和稳定性,包括主板、CPU、硬盘和内存等硬件设施...