来自有子查询的查询的交叉表查询 [英] Crosstab Query from a Query with a Subquery

查看:0
本文介绍了来自有子查询的查询的交叉表查询的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

有人能帮我解决一个交叉表查询比较供应商当前价格的问题吗? 它使用的SELECT查询有一个子查询,它只选择最新的价格进行价格比较,这对于我们需要的数据非常有效,请参见以下内容:

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。如果有人能帮上忙,我们将不胜感激!

推荐答案

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

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

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

这篇关于来自有子查询的查询的交叉表查询的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆