[英]SQL multiple and get the sum of different joined tables [duplicate]
我需要使用 MySQL 查询从实际价值价格和发货量以及订单数量中获取订单的利润。
请帮助使用连接查询查找结果。 订单表是订单数据的主表,库存表是我们的价格。 运费用于计算订单运费
为了查看价格详细信息,我们需要获取我们的价格和用户订购数量以及运费的总和
表:order-列出订单数据的主表
order_id | 姓名 | 订单金额 | 全部的 |
---|---|---|---|
125 | 苏尼尔 | 125 | 128 |
126 | 库里安 | 225 | 129 |
表:order_item - 单个订单商品详情
order_id | product_id | 数量 | 全部的 |
---|---|---|---|
125 | 12 | 2 | |
125 | 13 | 1 |
表:库存(个别产品实际价格)
product_id | 价格 | 项目代码 |
---|---|---|
12 | 30 | 宜家 |
13 | 40 | JUSWK |
shipping_table 运费。 因为有机会在多个表格中添加相同金额的运费。 我只需要一个订单的一个值
order_id | 收费 | 项目代码 |
---|---|---|
125 | 5 | 宜家 |
125 | 5 | 宜家 |
预期 output
order_id | 订单价格 | 实际价格 |
---|---|---|
125 | 125 | 105 |
我尝试了以下查询,但结果错误。
SELECT a.created_on ,
a.order_id,
a.order_amount,
sum(c.price*b.quantity),
FROM `order` AS `a`
INNER JOIN `order_item` AS `b` ON `a`.`order_id` = `b`.`order_id`
INNER JOIN `inventory` AS `c` ON `b`.`product_id` = `c`.`product_id`
INNER JOIN shipping_table
AS d
ON d
。 order_id
= a
。 order_id
WHERE a
。 order_id
= 125 GROUP BY a.order_id ORDER BY a.order_id
您可以在此连接内创建一个虚拟表。
你可以尝试这样的事情。
请检查由于此处使用的虚拟表的性质而可能出现的任何性能问题。 您可以使用 mysql 中的EXPLAIN ANALYZE
命令来检查性能问题
SELECT a.order_id, ordertot.tot
FROM order a JOIN
(SELECT order_id, SUM(order_item.quantity * inventory.price) AS tot FROM order_item JOIN inventory ON order_item.product_id = inventory.product_id GROUP BY order_id) AS ordertot
ON a.order_id = ordertot.order_id
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.