繁体   English   中英

SQL 多个并获得不同连接表的总和[重复]

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM