交叉表查询引用窗体控件值错误的解决方法
时 间: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高效办公】统计当...(06.30)
- 【Access高效办公】用复选...(06.24)
- 根据变化的日期来自动编号的示例...(06.20)
- 【Access高效办公】按日期...(06.12)
- 合并列数据到一个文本框的示例;...(05.06)
- 通过命令按钮让Access列表...(04.24)
- 【Access高效办公】统计当...(03.11)
- 【Access Inputbo...(03.03)
- 按回车键后光标移动到下一条记录...(02.12)

学习心得
最新文章
- Access快速开发平台--执行有...(07.03)
- 【Access高效办公】统计当月之...(06.30)
- 【Access高效办公】用复选框控...(06.24)
- 根据变化的日期来自动编号的示例;根...(06.20)
- Access快速开发平台--Acc...(06.16)
- 【Access高效办公】按日期区间...(06.12)
- Access快速开发平台--生成复...(06.07)
- 仓库管理实战课程(25)-导航菜单...(06.06)
- 仓库管理实战课程(24)-库存月结...(06.05)
- 分享一个简单的X氏家谱小示例(06.04)