4

我试图让一个有点复杂的查询工作并且没有任何运气。

假设我有以下表格:

购物车物品:

+--------------------------------------------+
| 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_perpricing表中获得适当的复杂性。每个 应该只返回一个价格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     |
+---------------------------------+

我遇到的麻烦是以一定数量的电影加入价格。我根本不知道该怎么做。

4

1 回答 1

1
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

问候。

于 2012-07-08T21:11:04.273 回答