带有子查询的查询中的交叉表查询

时间:2015-11-04 15:58:39

标签: ms-access ms-access-2010 ms-access-2007

任何人都可以帮我解决我在使用CrossTab查询来比较供应商的当前价格时遇到的问题吗? 它所使用的选择查询有一个子查询,它只选择我们价格比较的最新价格,这对我们需要的数据非常有效,见下文:

qryPriceComp:

SELECT tblPriceComp.SupplyerID, tblPriceComp.ProductID, 
    tblPriceComp.Effdt, tblPriceComp.CostPrice, 
    tblProduct.Product, tblSupplier.Supplier
FROM tblSupplier INNER JOIN 
    (tblProduct INNER JOIN tblPriceComp ON tblProduct.ProductID = tblPriceComp.ProductID) 
    ON tblSupplier.SupplierID = tblPriceComp.SupplyerID
WHERE (((tblPriceComp.Effdt) In 
    (SELECT MAX(B.EffDt) AS MaxOfDt FROM tblPriceComp AS B 
     WHERE tblPriceComp.ProductID=B.ProductID 
       AND tblPriceComp.SupplyerID=B.SupplyerID  
       AND B.EffDt <= Date()+1)));

然后将其用于交叉表查询 qryPriceComp_Crosstab:

TRANSFORM Sum(qryPriceComp.CostPrice) AS SumOfCostPrice
SELECT qryPriceComp.Product
FROM qryPriceComp
GROUP BY qryPriceComp.Product
ORDER BY qryPriceComp.Product, qryPriceComp.Supplier
PIVOT qryPriceComp.Supplier;

但是在运行时会出现错误,tblPriceComp.ProductID和tblSupplier.SupplierID都无效。我已经尝试将它们作为周边添加但是在运行时这给了一个框来输入ID号,这是不好的,因为我们想看到所有的productID和SupplyerID。如果有人能提供帮助,我们将不胜感激!

1 个答案:

答案 0 :(得分:0)

不是真正的解决方案,而是一种可用的解决方法:

qryPriceComp更改为INSERT INTO tempTable查询,然后将交叉表查询基于tempTable

在每次INSERT运行之前,必须执行DELETE * FROM tempTable