php – 如何使用至少每组查询进行左连接?

发布时间:2022-04-30 发布网站:脚本宝典
脚本宝典收集整理的这篇文章主要介绍了php – 如何使用至少每组查询进行左连接?脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。
我正试图让一个有点复杂的查询工作,并没有任何运气.

假设我有以下表格:

cart_ITems:

+--------------------------------------------+
| item_id  | cart_id | movie_name | quantity |
+--------------------------------------------+
|     0    |    0    | braveheart |    4     |
|     1    |    0    | braveheart |    9     |
|     .    |    .    |      .     |    .     |
|     .    |    .    |      .     |    .     |
|     .    |    .    |      .     |    .     |
|     .    |    .    |      .     |    .     |
+--------------------------------------------+

电影

+------------------------------+
| movie_id  | movie_name | ... |
+------------------------------+
|     0     | braveheart |  .  |
|     .     |     .      |  .  |
|     .     |     .      |  .  |
|     .     |     .      |  .  |
|     .     |     .      |  .  |
+------------------------------+

价钱:

+-----------------------------------------+
| id  | movie_name | quantity | PRice_PEr |
+-----------------------------------------+
|  0  | braveheart |    1     |   1.99    |
|  1  | braveheart |    2     |   1.50    |
|  2  | braveheart |    4     |   1.25    |
|  3  | braveheart |    8     |   1.00    |
|  .  |      .     |    .     |     .     |
|  .  |      .     |    .     |     .     |
|  .  |      .     |    .     |     .     |
|  .  |      .     |    .     |     .     |
|  .  |      .     |    .     |     .     |
+-----------------------------------------+

我需要加入表中的数据,但是我需要从定价表中获得适当的price_per.每个cart_item只应返回一个价格,这应该是定价表中的最低价格,其中购物车项目的数量至少是定价表中的数量.

因此,查询应该为cart_items中的每个项返回以下内容

+---------------------------------------------+
| item_id | movie_name | quantity | price_per |
+---------------------------------------------+

例1:

传递给查询的变量:cart_id = 0.返回:

+---------------------------------------------+
| item_id | movie_name | quantity | price_per |
+---------------------------------------------+
|    0    | braveheart |    4     |   1.25    |
|    1    | braveheart |    9     |   1.00    |
+---------------------------------------------+

请注意,这是一个极简主义的示例,并且将从所提到的表(特别是影表)中提取其他数据.

这个查询怎么能组成?我曾尝试使用左连接和子查询,但困难的部分是获得价格,我尝试过的任何工作都没有.

谢谢你的帮助.

编辑:

我认为这与我使用“真实”表的方式类似:

SELECT t1.item_id,t2.movie_name,t1.quantity
From cart_items t1
LEFT JOIN movies t2 ON t2.movie_name = t1.movie_name
WHERE t1.cart_id = 0

假设我写得正确(我很快试图“移植”我的真实查询),那么输出目前是:

+---------------------------------+
| item_id | movie_name | quantity |
+---------------------------------+
|    0    | braveheart |    4     |
|    1    | braveheart |    9     |
+---------------------------------+

我遇到的麻烦是加入一定数量的电影价格.我根本无法弄清楚该怎么做.

解决方法

SELECT t1.item_id,t1.movie_name,t1.quantity,t2.price_per
From cart_items t1
        INNER JOIN (
            SELECT c.quantity,c.movie_name,IF(p.price_per IS NOT NULL,MAX(p.price_per),MIN(p2.price_per)) AS `price_per`
            FROM cart_items c
                LEFT JOIN pricing p 
                    ON p.movie_name = c.movie_name 
                    AND p.quantity >= c.quantity
                LEFT JOIN pricing p2
                    ON p2.movie_name = c.movie_name 
                    AND p2.quantity < c.quantity
            group by c.quantity,c.movie_name
        ) t2 ON t2.movie_name = t1.movie_name AND t2.quantity = t1.quantity

小提琴:http://sqlfiddle.com/#!2/072e8

问候.

脚本宝典总结

以上是脚本宝典为你收集整理的php – 如何使用至少每组查询进行左连接?全部内容,希望文章能够帮你解决php – 如何使用至少每组查询进行左连接?所遇到的问题。

如果觉得脚本宝典网站内容还不错,欢迎将脚本宝典推荐好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。