我需要一个查询来获取实际库存的概览(每个唯一产品ID只有一行)以及所有销售和采购订单 . 现在,我们使用两个子查询(销售和采购订单),因为可能有多个销售和采购订单 . 由于有两个子查询,此查询非常慢 . 是否有另一种方法可以获得销售订单的总和和采购订单的总和,例如常规的左连接?
当前查询
SELECT stock.quanity, salesOrders.quantity, purchaseOrders.quantity
FROM stock
LEFT JOIN (
SELECT product_id, sum(quantity) as quantity
FROM sales_orders
GROUP BY product_id
) salesOrders ON stock.product_id=salesOrders.product_id
LEFT JOIN (
SELECT product_id, sum(quantity) as quantity
FROM purcahse_orders
GROUP BY product_id
) purchaseOrders ON stock.product_id=purchaseOrders.product_id
1 回答
正确索引可能会使相关子查询更快:
为了能够提高性能,您需要
sales_orders(product_id, quantity)
和purchase_orders(product_id, quantity)
上的索引 .