交叉表查询引用窗体控件值错误的解决方法
时 间:2014-06-14 09:13:13
作 者:杜超-2号 ID:16058 城市:江阴
摘 要:Access有时候真的不太听话!
建立了一个普通的汇总查询,其中包含了窗体上几个文本框的值,查询语句如下所示:
正 文:
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;
如此就解决了交叉表查询无法正确引用窗体控件值的问题。
Access软件网QQ交流群 (群号:54525238) Access源码网店
常见问答:
技术分类:
源码示例
- 【源码QQ群号19834647...(12.17)
- 【Access选项卡示例】Ac...(09.09)
- 【Access源码示例】按输入...(09.02)
- 【Access日期区间段查询】...(08.29)
- 【Access日期区间段查询】...(08.27)
- Access怎样才能实现日期时...(08.21)
- 【Access定时打开查询】A...(08.19)
- Access生成固定数量的记录...(08.13)
- Access怎样才能实现日期时...(08.12)
- Access利用导航窗体控件对...(08.03)
学习心得
最新文章
- Access表中的字段名、字段标题...(09.19)
- Access快速开发平台--更改“...(09.18)
- 【中秋及国庆优惠】Access培训...(09.15)
- Access如何将日期型的数值转换...(09.14)
- 英文输入法输入数据中存在单引号引起...(09.11)
- 【Access选项卡示例】Acce...(09.09)
- 让Access光标停留在指定的控件...(09.07)
- 关于Access查询条件里使用通配...(09.06)
- Access报表偷懒制作法--Ac...(09.05)
- Access快速开发平台--窗体数...(09.04)