为库存SQL查询获取歧义错误,其中两个字段应该相等以进行计算。 MS-ACCESS

时间:2017-07-29 14:53:40

标签: sql database ms-access join inventory

有了this simple group of tables,我想制作一个清单来区分来自不同提供商的同等产品,但我得到一个“模糊错误”运行查询我虽然它会起作用。我不知道如何解决这个问题。

这是我试过的查询:

SELECT tblProducts.product_Name, 
       tblProviders.provider, 
       Nz(Sum(tblIntakes.intake_QTY),0)-
       Nz(Sum(tblExits.exit_QTY)) AS Stock

FROM tblProviders, 
     (tblProducts LEFT JOIN 
     tblExits 
     ON tblProducts.product_ID = tblExits.product_ID
     ) LEFT JOIN 
     tblIntakes 
     ON tblProducts.product_ID = tblIntakes.product_ID

GROUP BY tblProducts.product_Name, tblProviders.provider;

1 个答案:

答案 0 :(得分:0)

在这种情况下,您可以使用子查询:

SELECT
  tblProducts.product_Name,
  tblProviders.provider,
  Nz((
    SELECT SUM(intake_QTY)
    FROM tblIntakes
    WHERE
      tblIntakes.product_ID = tblProducts.product_ID AND
      tblIntakes.provider_ID = tblProviders.provider_ID
  ), 0) -
  Nz((
    SELECT SUM(exit_QTY)
    FROM tblExits
    WHERE
      tblExits.product_ID = tblProducts.product_ID AND
      tblExits.provider_ID = tblProviders.provider_ID
  ), 0) AS Stock
FROM tblProviders, tblProducts;