gpt4 book ai didi

php - 如何使用 least-n-per-group 查询进行左连接?

转载 作者:可可西里 更新时间:2023-11-01 07:41:21 27 4
gpt4 key购买 nike

我试图让一个有点复杂的查询正常工作,但我一点运气都没有。

假设我有以下表格:

购物车商品:

+--------------------------------------------+
| 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 |
| . | . | . | . |
| . | . | . | . |
| . | . | . | . |
| . | . | . | . |
| . | . | . | . |
+-----------------------------------------+


我需要连接表中的数据,但增加了复杂性,我需要从 pricing 表中获取适当的 price_per。每个 cart_item 只应返回一个价格,并且该价格应该是 pricing 表中的最低价格,其中购物车商品的 quantity 是至少是 pricing 表中的数量。

因此,查询应该为 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

fiddle :http://sqlfiddle.com/#!2/072e8

问候。

关于php - 如何使用 least-n-per-group 查询进行左连接?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11385483/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com