关于Laravel多个条件的关联查询问题 ?

PHP中文网
发布: 2017-03-21 16:18:45
原创
4735人浏览过

关于laravel多个条件的关联查询问题 :

order 订单表:

  • id 自增ID

  • order_id 订单号

  • paid_date 支付时间

order_product 订单产品表:

  • id 自增ID

  • fk_order_id 订单号,外键

  • product_name 名称

  • product_number 编号

  • quantity 数量

表关系:

汉潮代驾系统
汉潮代驾系统

如今有越来越多的人在网上做代驾,打造一个代驾平台,既可以让司机增加一笔额外的收入,也解决了车主酒后不能开发的问题,汉潮代驾系统基于微信小程序开发的代驾系统支持一键下单叫代驾,支持代驾人员保证金功能,支持代客下单,支持代驾人员订单调度及代驾人员位置查看,欢迎大家关注我们。 汉潮代驾系统是汉潮唐越科技有限公司研发团队自主开发的代驾系统,包含后台系统和微信小程序,主要功能模块商家设置,会员管理,营销管理

汉潮代驾系统 0
查看详情 汉潮代驾系统
order - 1:n - order_product
登录后复制

需求:
通过 Laravel Eloquent ORM 实现以下原生 SQL:

select * from order as A inner join order_product as B on A.order_id=B.fk_order_id 
where (A.paid_date between '2016-01-01' and '2016-09-01') and B.product_name like '%Apple iPhone%'
登录后复制

手册看了几次,尝试着做,但目前只通过 whereHas 实现 B.product_name like 这部分的条件,当两个表都存在条件的时候,实在是做不出来。
望 Laravel 前辈们指点一下,谢谢!

PS. 补充:
目前是针对列表页做筛选检索,存在 paginate 的需求。

解决方法:

class Order extends Model
{
    public function scopeProducts($query)
    {
        return $query->join('order_product', function($join) {
            $join->on('order.order_id', '=', 'order_product.fk_order_id');
        });
    }
}
登录后复制
Order::products()->where(....);
登录后复制

以上就是关于Laravel多个条件的关联查询问题 的内容,更多相关内容请关注PHP中文网(www.php.cn)!

相关文章:

Laravel 关联查询只获取管理对象的部分数据

laravel 关联查询问题

laravel 关联查询文章和文章作者

相关标签:
最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号