首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Laravel中的多表Mysql联合查询

Laravel中的多表Mysql联合查询
EN

Stack Overflow用户
提问于 2020-03-18 12:52:09
回答 2查看 88关注 0票数 1

我正在尝试连接两个表Customer和Customer_Usage以获取result.Tables,如下所示。

表:客户

代码语言:javascript
复制
+----+-------+-------------+--------+
| id | Ip_Id | Customer_Id | Class  |
+----+-------+-------------+--------+
| 1  | 100   | A           | First  |
| 2  | 100   | B           | First  |
| 3  | 100   | C           | First  |
| 4  | 101   | D           | First  |
| 5  | 101   | E           | First  |
| 6  | 100   | F           | Second |
+----+-------+-------------+--------+

表: Customer_Usage

代码语言:javascript
复制
+----+-------------+----------------+
| id | Customer_Id | Usage          |
+----+-------------+----------------+
| 1  | A           | 1245           |
| 2  | B           | 4414           |
| 3  | C           | 8521           |
| 4  | D           | 2314           |
| 5  | E           | 521            |
| 6  | F           | 5412           |
+----+-------------+----------------+

条件是,当输入搜索Ip_Id的值时,例如100,它将给出如下所示的结果。如何使用Mysql在Laravel中对这两个表进行连接

输出结果

代码语言:javascript
复制
+-------+-------------+----------------+
| Ip_Id | Customer_Id | Usage          |
+-------+-------------+----------------+
| 100   | A           | 1245           |
| 100   | B           | 4414           |
| 100   | C           | 8521           |
| 100   | F           | 5412           |
+-------+-------------+----------------+

这是我正在尝试的查询。

代码语言:javascript
复制
 $result        = DB::table('Customer')
                ->where('Ip_Id','=','100')
                ->get();
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2020-03-18 13:00:50

像这样使用Eloquent Inner Join

代码语言:javascript
复制
$results  = DB::table('Customer')
->select('Customer.Ip_Id','Customer.Customer_Id', 'Customer_Usage.Usage')
->join('Customer_Usage','Customer.Customer_Id', '=','Customer_Usage.Customer_Id')
->where('Ip_Id', 100)                
->get();

您将获得如上所需的输出。

票数 0
EN

Stack Overflow用户

发布于 2020-03-18 13:19:11

推荐使用Left join来实现您所需的功能。

代码语言:javascript
复制
DB::table('Customer')
            ->select('Customer.Ip_Id','Customer.Customer_Id','Customer_Usage.Usage')
            ->leftJoin('Customer_Usage', 'Customer_Usage.Customer_Id', '=', 'Customer.Customer_Id')
            ->where('Customer.Ip_Id',100)
            ->get();
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/60733713

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档