Access交流中心

北京 | 上海 | 天津 | 重庆 | 广州 | 深圳 | 珠海 | 汕头 | 佛山 | 中山 | 东莞 | 南京 | 苏州 | 无锡 | 常州 | 南通 | 扬州 | 徐州 | 杭州 | 温州 | 宁波 | 台州 | 福州 | 厦门 | 泉州 | 龙岩 | 合肥 | 芜湖 | 成都 | 遂宁 | 长沙 | 株洲 | 湘潭 | 武汉 | 南昌 | 济南 | 青岛 | 烟台 | 潍坊 | 淄博 | 济宁 | 太原 | 郑州 | 石家庄 | 保定 | 唐山 | 西安 | 大连 | 沈阳 | 长春 | 昆明 | 兰州 | 哈尔滨 | 佳木斯 | 南宁 | 桂林 | 海口 | 贵阳 | 西宁 | 乌鲁木齐 | 包头 |

求大侠解决筛选问题

alex0516  发表于:2014-07-15 14:24:54  
复制

�������ش˸���

 

附件做了一个表

 

表1
零件 销售价格 销售成本 差异
AAA 100 50 30
BBB 200 80 20

 

然后做了个查询,并增加了成本合计= 成本+差异,以及成本率=成本合计/销售价格,然后想筛选成本率,但是就报错了,是什么原因呢?如何解决。

 

Top
煮江品茶 发表于:2014-07-15 15:02:23
select *,销售成本+差异 as 成本合计,iif(销售价格=0,0,(销售成本+差异)/销售价格) as 成本率
from 阁下的数据表


alex0516 发表于:2014-07-15 15:29:28

谢谢,但为什么access不能直接使用计算过的数据呢,如果要用几个计算结果进行比较,难道只能重头再做一遍输入吗,有没有简单的方法?



煮江品茶 发表于:2014-07-15 15:53:12

可以呀。

select a.*,a.销售成本+a.差异 as 成本合计,iif(a.销售价格=0,0,[成本合计]/a.销售价格) as 成本率
from 阁下的数据表 as a



alex0516 发表于:2014-07-15 16:34:38

我用了以下公式:

SELECT 表1.零件, 表1.销售价格, 表1.销售成本, 表1.差异, 表1.销售成本+表1.差异 AS 成本合计, IIf(表1.销售价格=0,0,[成本合计]/表1.销售价格) AS 成本率
FROM 表1
WHERE (((IIf(表1.销售价格=0,0,[成本合计]/表1.销售价格))>0.5));

但是当要筛选成本率大于50%时,就报错了,是什么原因呢?



煮江品茶 发表于:2014-07-16 11:07:32

where子句中不能用计算列




alex0516 发表于:2014-07-16 11:32:52
但是我最终是要筛选成本率超过50%的,如何做呢?

飘摇王 发表于:2014-07-16 13:52:30
SELECT a.*, a.销售成本+a.差异 AS 成本合计, IIf(a.销售价格=0,0,(a.销售成本+a.差异)/a.销售价格) AS 成本率
FROM 表1 AS a
WHERE IIf(a.销售价格=0,0,(a.销售成本+a.差异)/a.销售价格) >0.5;



alex0516 发表于:2014-07-16 16:20:12
to 飘摇王,IIf(a.销售价格=0,0,(a.销售成本+a.差异)/a.销售价格) AS 成本率,公式里为什么改成[成本合计]后就无法做筛选了,因为还要用成本率做进一步做计算,难道每次都要全部写一遍?


飘摇王 发表于:2014-07-17 08:57:30
应该是这样的,我的理解是表里不存在【成本合计】,使用查询创建的项目,代码为执行完,应该找不到【成本合计】

总记录:9篇  页次:1/1 9 1 :