Access开发培训
网站公告
·Access专家课堂QQ群号:151711184    ·Access快速开发平台下载地址及教程    ·欢迎加入Access专家课堂微信群!    ·如何快速搜索本站文章|示例|资料    
您的位置: 首页 > 技术文章 > Access数据库-查询/SQL语句

交叉表查询引用窗体控件值错误的解决方法

时 间: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交流群 (群号:483923997)       Access源码网店

常见问答:

技术分类:

相关资源:

专栏作家

关于我们 | 服务条款 | 在线投稿 | 友情链接 | 网站统计 | 网站帮助