php – 如何使用至少每组查询进行左连接?
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了php – 如何使用至少每组查询进行左连接?,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含3352字,纯文字阅读大概需要5分钟。
内容图文
![php – 如何使用至少每组查询进行左连接?](/upload/InfoBanner/zyjiaocheng/770/849028d5def9418db6f12f6f78ea9c10.jpg)
我正试图让一个有点复杂的查询工作,并没有任何运气.
假设我有以下表格:
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 – 如何使用至少每组查询进行左连接?所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。