php – 如何使用至少每组查询进行左连接?
发布时间:2020-12-13 22:44:25 所属栏目:PHP教程 来源:网络整理
导读:我正试图让一个有点复杂的查询工作,并没有任何运气. 假设我有以下表格: cart_items: +--------------------------------------------+| item_id | cart_id | movie_name | quantity |+--------------------------------------------+| 0 | 0 | braveheart
我正试图让一个有点复杂的查询工作,并没有任何运气.
假设我有以下表格: 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 问候. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |