【Access小品】从一个错误说起--域函数第一参数问题-煮江品茶
Access软件网QQ交流学习群(群号码198465573),欢迎您的加入!
首页 >技术文章> 程序人生


【Access小品】从一个错误说起--域函数第一参数问题

发表时间:2013/4/14 21:31:27 评论(0) 浏览(5572)  评论 | 加入收藏 | 复制
   
摘 要:【Access小品】从一个错误说起--域函数第一参数问题
正 文:

  有版友看到了这样一个令人困惑域函数写法:DSUM("1","数据$","F1&F2<='" & F1 & F2 & "'")


    金宇同志说此处的1应该是表中的某个字段名。真是这样吗?其实不然,如果写这个函数的人确实没有搞错的话,这个1不代表字段名。它是什么呢?其实这个函数的结果与Dcount("*","数据$","F1&F2<='" & F1 & F2 & "'")是一致的,也就是按某个条件统计记录条数。如果把第一个参数换成2的话,那么就是某种条件下记录条数的两倍。


  Dsum函数的第一个参数是字段名吗?由上面的例子可以看出,显然不是。那么第一参数到底是什么呢?其实它是一个字段变量的表达式。表达式的概念比较大,一个字段变量是表达式,若干个字段变量采用某些运算符和函数组合起来也是表达式,同样常数也是表达式。所以第一个参数可以用一个常数,因为这就是表达式。


  我常常看见版友将多个Dsum函数相加或者其他四则运算的情况。大多数情况下是不必要这样处理的,你可以直接在第一个参数中用表达来进行运算。说一个比较典型的例子,我们在计算库存时,需要用Dsum计算出一个期间的累计收入和累计发出,你当然可以用两个Dsum来计算。但是你如果注意到第一个参数是字段表达式的话,那么用一个Dsum就足够了,因为你可以把收发字段放到第一个参数中相减就可以了。


  不过并非都可以将表达式写入第一个参数中,因为你需要考虑计算的逻辑。比如说你可以用单价字段和数量字段的乘积做为表达式,放入第一个参数中来求总金额。但这并不意味着,你可以将金额除以数量放入第一个参数中来求平均单价。


  DSUM("1","数据$","F1&F2<='" & F1 & F2 & "'") 的写法到底错了没错呢?这要看判断是非的标准了。如果以便于理解的角度讲,这种写法是不对的。代码应该尽可能的清晰和便利理解,如果有更恰当的代码书写方式,应该采用这些方式。过于怪异的写法不是好的习惯。


Access软件网交流QQ群(群号:198465573)
 
 相关文章
ADP 中“域聚合函数”  【UMVSOFT整理  2007/11/8】
在窗体间传递参数的几种常用办法  【UMVsoft整理  2007/11/20】
《变量的作用域》  【UMVSoft整理  2009/5/7】
[示例]域聚合函数使用示例  【钱玉炜  2009/6/16】
设置查询参数的数据类型  【蒋元根  2013/3/8】
常见问答
技术分类
相关资源
文章搜索
关于作者

煮江品茶

文章分类

文章存档

友情链接