博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
laravel 中将一对多关联查询的结果去重处理
阅读量:4359 次
发布时间:2019-06-07

本文共 902 字,大约阅读时间需要 3 分钟。

先交代下数据表结构

  • 主表(订单表)order数据
ord_id order_sn
1 EX2019100123458

其中主键为order_id(订单id)

  • 子表(门票表)order_item数据
ord_ite_id ord_id exhibit_sn type
1 1 EXSN20191001001 1
2 1 EXSN20191001002 1
3 1 EXSN20191001003 1

主表与子表之间通过 ord_id进行关联

实现:通过通过子表的 type(门票类型)查询主表中的订单编号

  第一种尝试:

select DISTINCT `order`.ord_id from `order` INNER JOIN order_item on order.ord_id = order_item.ord_id where type = 1;

这种方法可以实现但是在laravel中如果想分页的话需要这么使用

DB::table(DB::raw("sql语句"))->paginate(15);

但是这样的话我们相当于使用的原生sql语句,但是如果在添加条件的话只能去拼接sql语句啦

  第二种尝试:

select `order`.ord_id,`order`.order_sn from `order` INNER JOIN (select distinct ord_id from order_item) r on `order`.ord_id=r.ord_id

在larave中使用

Order::join(DB::raw("(select distinct order_item.ord_id item_ord_id,type from order_item) ".env("DB_PREFIX")."bb"),"bb.item_order_id","exhibit_order.order_id")->paginate(15);

这样我们可以继续使用 where() 方法来添加条件

转载于:https://www.cnblogs.com/itsuibi/p/11617512.html

你可能感兴趣的文章
【转】你可能不知道的Shell
查看>>
廖雪峰Java1-2程序基础-1基本结构
查看>>
golang下的grpc
查看>>
1. 自动化运维系列之Cobbler自动装机
查看>>
ASP.NET MVC Model绑定(二)
查看>>
一步一步写算法(之hash表)
查看>>
漫谈并发编程(一) - 并发简单介绍
查看>>
JDBC连接MySQL数据库及演示样例
查看>>
Beta 冲刺(1/7)
查看>>
修改 Vultr 登录密码
查看>>
CSS学习
查看>>
Centos 安装lnmp完整版
查看>>
【转】Eclipse和PyDev搭建完美Python开发环境(Ubuntu篇)
查看>>
redis安装和配置
查看>>
2016424王启元 Exp5 msf基础应用
查看>>
Differences between page and segment
查看>>
Jdk与Tomcat配置与安装
查看>>
关于一个Java web与JFrame的深度结合
查看>>
VB连数据库conn.open的参数
查看>>
《信息安全系统设计基础》实验三
查看>>