【问题标题】:DSum returning number of rows instead of total valueDSum 返回行数而不是总值
【发布时间】:2011-05-27 21:38:00
【问题描述】:

我在表单中的文本框中附加了以下代码:

=DSum("[subform].Form![POINTS]","ATTENDANCE","[subform].Form![EMPLOYEE NO] = [EMPLOYEE NO]")

理想情况下,这将产生我们当前正在搜索的员工所累积的总积分。但是,我得到的是表中的总行数。

有人知道我如何获得值的总和而不是行数吗?

谢谢

【问题讨论】:

    标签: ms-access ms-access-2007 ms-access-2003


    【解决方案1】:

    如果您想从子表单中获取总数,并且您的子表单与主表单同步,则以这种方式进行会更有效率:

    1. 在子表单的页脚中创建 txtTotalPoints 文本框 = sum(Points)
    2. 在主窗体中引用该控件:txtMainResult =subform!form!txtTotalPoints
    3. 隐藏 txtTotalPoints(或页脚本身)

    这通常会快得多。

    【讨论】:

    • 完美运行!非常感谢您的帮助。
    【解决方案2】:

    据我所知,DSum、DLookup、DCount 等域函数用于从表中查找和返回值。第一个参数是字段,第二个参数是表,第三个是标准或 WHERE 语句,以确保您获得正确的记录集。您的第一个参数是指表单的字段。我认为这是不正确的。 WHERE 语句中的第一项也是表单域。我这也是不正确的。你需要尝试这样的事情:

    =DSum("POINTS","ATTENDANCE","[EMPLOYEE NO] = " & [subform].Form![EMPLOYEE NO])
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2013-11-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多