DSum 返回行数而不是总值
Posted
技术标签:
【中文标题】DSum 返回行数而不是总值【英文标题】:DSum returning number of rows instead of total value 【发布时间】:2011-05-27 21:38:00 【问题描述】:我在表单中的文本框中附加了以下代码:
=DSum("[subform].Form![POINTS]","ATTENDANCE","[subform].Form![EMPLOYEE NO] = [EMPLOYEE NO]")
理想情况下,这将产生我们当前正在搜索的员工所累积的总积分。但是,我得到的是表中的总行数。
有人知道我如何获得值的总和而不是行数吗?
谢谢
【问题讨论】:
【参考方案1】:如果您想从子表单中获取总数,并且您的子表单与主表单同步,则以这种方式进行会更有效率:
-
在子表单的页脚中创建 txtTotalPoints 文本框
= sum(Points)
在主窗体中引用该控件:txtMainResult =subform!form!txtTotalPoints
隐藏 txtTotalPoints(或页脚本身)
这通常会快得多。
【讨论】:
完美运行!非常感谢您的帮助。【参考方案2】:据我所知,DSum、DLookup、DCount 等域函数用于从表中查找和返回值。第一个参数是字段,第二个参数是表,第三个是标准或 WHERE 语句,以确保您获得正确的记录集。您的第一个参数是指表单的字段。我认为这是不正确的。 WHERE 语句中的第一项也是表单域。我这也是不正确的。你需要尝试这样的事情:
=DSum("POINTS","ATTENDANCE","[EMPLOYEE NO] = " & [subform].Form![EMPLOYEE NO])
【讨论】:
以上是关于DSum 返回行数而不是总值的主要内容,如果未能解决你的问题,请参考以下文章