ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 效率神器,一键搞定繁琐工作
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
让更多数据处理,一键完成 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
查看: 2560|回复: 14

[求助] 怎么在ACCESS 里用VBA 做计算呢?

[复制链接]

TA的精华主题

TA的得分主题

发表于 2014-6-3 23:22 | 显示全部楼层 |阅读模式
本帖最后由 jiaqitang 于 2014-6-3 23:24 编辑


我有一个数据库,里边有一个表”DAYS”(共三列,PIN,DAYS,SCORES,表是按SCORES从大到小排列).我做了一个查询(DaysScores),算出了DAYS的总和(5095666),SCORES的最大值,还有BENCKMARK(DAYS总和乘上0.35,在这个表里它是1783483.1)
我想做的计算是从上到下累加DAYS 表里 DAYS 这一列,当总和数大于1783483.1,停止累加. 这时算出一共有多少的PIN(就是多少个行数,在这个表里,加到第64行时,总值是1810594>1783483.1,停止累加,64PIN,我想把这个64 的值输入到我创建的窗体中”COUNT”那一栏, 总和数1810594输入窗体中”SUM”那一栏.
能实现吗? 请高手指教?


Database1.zip (38.63 KB, 下载次数: 11)

TA的精华主题

TA的得分主题

 楼主| 发表于 2014-6-4 10:22 | 显示全部楼层
很复杂?没人懂吗?

TA的精华主题

TA的得分主题

发表于 2014-6-4 14:45 | 显示全部楼层
无法理解用途。另,因涉及排序,但Days表没有自动ID字段,可能出现计算错误现象。

Database1.zip

43.23 KB, 下载次数: 18

TA的精华主题

TA的得分主题

 楼主| 发表于 2014-6-4 20:19 | 显示全部楼层
styhs 发表于 2014-6-4 14:45
无法理解用途。另,因涉及排序,但Days表没有自动ID字段,可能出现计算错误现象。

谢谢高手,应该是对的。以前我们的系统是VB6.0 编写的,老板想把它改成EXCEL,或ACCESS 形式,所以。。。

TA的精华主题

TA的得分主题

 楼主| 发表于 2014-6-5 06:17 | 显示全部楼层
本帖最后由 jiaqitang 于 2014-6-5 06:37 编辑

Database1.zip (46.96 KB, 下载次数: 9)

我又加了一个文本框,在算出了多少行数后(这里是64行)把表DAYS中这个行(第64行)对应的SCORE赋给文本框, 怎么弄呢?

TA的精华主题

TA的得分主题

发表于 2014-6-5 07:30 | 显示全部楼层
jiaqitang 发表于 2014-6-5 06:17
我又加了一个文本框,在算出了多少行数后(这里是64行)把表DAYS中这个行(第64行)对应的SCORE赋给文本 ...

Private Sub Command23_Click()
.....
        .Source = "SELECT Days,Scores FROM Days"
    ....
            If FSumNum > FNum Then
                ...
                FScores = .Fields("Scores")
                Exit Do
            End If
...
    With Me
...
        .Text24 = Format(FScores, "0.00")
    End With
  ...
End Sub

TA的精华主题

TA的得分主题

 楼主| 发表于 2014-6-5 07:45 | 显示全部楼层
本帖最后由 jiaqitang 于 2014-6-5 10:02 编辑
ly 发表于 2014-6-5 07:30
Private Sub Command23_Click()
.....
        .Source = "SELECT Days,Scores FROM Days"


谢谢,运行OK,为啥FScores = .Fields("Scores")就是代表最后那一行呢(第64行), 第一行该怎么表示呢?
我又加了两个文本框,AVERAGE和CUTOFF, AVERAGE它是等于 查询“DAYSSCORES”里TOTALDAY 那个数值除以所有这64行DAYS*SCORE 的总和:TOTALDAYS/SUM(DAYS*SCORES)

CUTOFF 等于文本框SUM里的值除以所有这64行DAYS*SCORE 的总和:SUM()/SUM(DAYS*SCORES)


怎么办。。。。。



Database1.zip (77.14 KB, 下载次数: 9)


TA的精华主题

TA的得分主题

 楼主| 发表于 2014-6-5 10:05 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2014-6-5 19:13 | 显示全部楼层
jiaqitang 发表于 2014-6-5 07:45
谢谢,运行OK,为啥FScores = .Fields("Scores")就是代表最后那一行呢(第64行), 第一行该怎么表示呢?
...

也不知道理解的是否正确,先上个附件说:
Database1.rar (48.32 KB, 下载次数: 11)

TA的精华主题

TA的得分主题

 楼主| 发表于 2014-6-5 20:03 | 显示全部楼层
谢谢,是正确的,但我还是不懂啥FScores = .Fields("Scores")就是代表最后那一行呢(第64行), 第一行该怎么表示呢
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2024-12-26 23:27 , Processed in 0.045131 second(s), 11 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

快速回复 返回顶部 返回列表