0

我对基于包含子查询的查询的交叉表查询有疑问。查询本身工作正常,但是当我在交叉表查询中使用它时,我收到一条与无法识别的字段名称相关的错误消息,并指向子查询中使用的字段。奇怪的是,我可以毫无问题地在此查询上定义数据透视表或数据透视图。

因此,查询TestqryMeasurement定义为:

SELECT *, 
    (SELECT min( subMeas.MeasDate ) FROM tblMeasurement AS subMeas 
     WHERE subMeas.idTest = mainMeas.idTest AND subMeas.idMovement = 
     mainMeas.idMovement) AS FirstMeasDate, 
    DateDiff("d",FirstMeasDate,MeasDate) AS DaysSinceFirstMeas
FROM tblMeasurement AS mainMeas;

它主要用于确定给定测试中给定运动的第一次测量和当前测量之间花费的时间。运行此查询时,我得到正确的结果。

然后编写交叉表查询:

TRANSFORM Sum(TESTqryMeasurement.[Amplitude]) AS SumOfAmplitude
SELECT TESTqryMeasurement.[DaysSinceFirstMeas], 
    Sum(TESTqryMeasurement.[Amplitude]) AS [Total Of Amplitude]
FROM TESTqryMeasurement
GROUP BY TESTqryMeasurement.[DaysSinceFirstMeas]
PIVOT TESTqryMeasurement.[idMovement];

当我运行它时,我收到消息:

...数据库引擎无法将“mainMeas.idTest”识别为有效的字段名称或表达式

该字段仅在其TestqryMeasurement本身有效的子查询中使用。

任何想法?

注意:我有 Ms-Access v.14,是 MS-Office 2010 的一部分

- 编辑 -

我设法通过用返回第一次测量日期的 VBA 函数替换子查询来使事情正常进行。尽管如此,这个解决方案还是不太好,因为交叉表查询的性能损失很大(有或没有计算字段)。奇怪的是查询本身具有与 VBA 函数或等效子查询相当的性能......

4

1 回答 1

1

@DHW 已经给了我答案。这个想法是通过将查询与其自身的子集连接起来完全避免子查询,该子集包含所需子查询的结果。这不仅有效,而且还避免了在调用自定义 VBA 函数替换子查询时遇到的性能损失。

就我而言,解决方案如下:

1) 定义查询 - qryFirstMeasDate- 给出每个测试和运动的第一个测量日期:

SELECT idTest, idMovement, min( MeasDate ) AS FirstMeasDate
FROM tblMeasurement
GROUP BY idTest, idMovement;

2)将此查询与主测量表连接以获得整体测量查询qryMeasurement

SELECT tblMeasurement.*, FirstMeasDate, DateDiff("d",FirstMeasDate,MeasDate) AS   
   DaysSinceFirstMeas
FROM tblMeasurement INNER JOIN qryFirstMeasDate ON 
   (tblMeasurement.idMovement = qryFirstMeasDate.idMovement) AND 
   (tblMeasurement.idTest = qryFirstMeasDate.idTest);

qryMeasurement3)按照问题帖子中的方式编写交叉表查询。

再次感谢 DHW!

于 2013-10-03T12:09:30.417 回答