Select middle.delivery, middle.equipment,
Sum(sumbatch*worktime/yield/forms!FCSTcapacity!txtparaday/forms!FCSTcapacity!txtparahour/60/middle.number)
AS loading FROM middle GROUP BY middle.delivery, middle.equipment
查询结果正常。后来为了调整格式,又在此查询的基础上采用交叉表查询,以更好的方式呈现结果,查询语句如下所示:
TRANSFORM wloading.loading AS loading之總計 Select wloading.equipment FROM wloading GROUP BY wloading.equipment PIVOT wloading.delivery
本来以为没什么问题,因为只是格式的转换而已,没想到,当运行查询时却提示以下错误:
真是郁闷,自己捣鼓了半天,在论坛上问了很多人,都没有弄明白,因为这个窗体控件确实是赋值了的,而且引用的方式和写法完全都没有问题,所以最终确定是Access本身的事情,人家就是不让你这么写!
没办法,只好曲线救国了!
既然交叉表查询不让引用窗体控件值,那咱就不引用,可又怎么保证结果随着窗体控件值的变化而变化呢,也就是说交叉表查询要求使用一张有具体数值的表,而实际需求根据控件值进行查询,所以我们就想到了一种查询方法——生成表查询,也就是说查询的结果生产了一张普通的不能再普通的表,而这张表肯定是可以被交叉表查询所使用的。
所以写下这个生成表查询语句:
Select Middle.delivery, Middle.equipment,
Sum([sumbatch]*[worktime]/[yield]/Val(forms!FCSTcapacity!txtparaday)/Val(forms!FCSTcapacity!txtparahour)/60/middle.number)
AS loading INTO wloading FROM Middle GROUP BY Middle.delivery, Middle.equipment
然后再在生产的表上建立交叉表查询:
TRANSFORM format$(Sum(wloading.loading),"percent") AS loading之總計 Select wloading.equipment FROM wloading GROUP BY wloading.equipment PIVOT wloading.delivery;
如此就解决了交叉表查询无法正确引用窗体控件值的问题。