Foxtable(狐表)用户栏目专家坐堂 → 请教月和年累计用什么方法比较好


  共有3717人关注过本帖树形打印复制链接

主题:请教月和年累计用什么方法比较好

帅哥哟,离线,有人找我吗?
sxqq123
  1楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:小狐 帖子:300 积分:2307 威望:0 精华:0 注册:2012/11/14 11:25:00
请教月和年累计用什么方法比较好  发帖心情 Post By:2013/9/8 10:27:00 [只看该作者]

 下载信息  [文件大小:   下载次数: ]
图片点击可在新窗口打开查看点击浏览该文件:测试累计效率.table

 


图片点击可在新窗口打开查看此主题相关图片如下:方法1耗时.jpg
图片点击可在新窗口打开查看

图片点击可在新窗口打开查看此主题相关图片如下:方法2耗时.jpg
图片点击可在新窗口打开查看


通过查询表形式将每天的新水用量导入表A,现在要统计每月和全年累计用量,我使用了三种方法,
1、用SUM直接统计最初日期到当天的用量,帮助上《非等于比较》章节说这种方法效率较低。

2、采用查询与赋值并存〉方法耗时更长,感觉不适合。

3、采用高效流水帐方法,因为原始数据是通过查询表形式导入的,重置列肯定会耗时更长,在实际使用过程中采用按月筛选显示,每月最后一天用量统计显示不正确,请教可能是什么原因?

现采用第一种方法,因原始列有20列,统计耗时较长,请教大师指教采用什么方法更好。


 回到顶部
帅哥哟,离线,有人找我吗?
有点酸
  2楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:五尾狐 帖子:1093 积分:6682 威望:0 精华:0 注册:2013/7/1 9:05:00
  发帖心情 Post By:2013/9/8 11:01:00 [只看该作者]

看你的图片,第一种方法很快的了,何必纠结呢。

 回到顶部
帅哥哟,离线,有人找我吗?
sxqq123
  3楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:小狐 帖子:300 积分:2307 威望:0 精华:0 注册:2012/11/14 11:25:00
  发帖心情 Post By:2013/9/8 11:04:00 [只看该作者]

1、现采用第一种方法,因原始数据列有20列,统计耗时较长,请教大师指教采用什么方法更好。

2、采用高效流水帐方法,在实际使用过程中采用按月筛选显示,每月最后一天用量统计显示不正确,请教可能是什么原因?


 回到顶部
帅哥哟,离线,有人找我吗?
有点酸
  4楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:五尾狐 帖子:1093 积分:6682 威望:0 精华:0 注册:2013/7/1 9:05:00
  发帖心情 Post By:2013/9/8 11:36:00 [只看该作者]

另外做个按钮,按钮代码:

 

Dim st As Date = Date.Now
'DataTables("表A").StopRedraw()
Dim drs As List(of DataRow) = DataTables("表A").Select("","日期")
For i As Integer = 0 To drs.count -1
    Dim dr As DataRow = drs(i)
    Dim y As Integer = dr("日期").year
    Dim m As Integer = dr("日期").Month
    Dim d As Integer = dr("日期").day
    Dim year As String = IIF(m=12 And d>=26,y+1,y)
    Dim month As String = IIF(d>=26,IIF(m=12,1,M+1),m)
    Dim EndDate As Date = new Date(year, month, 26)
    Dim StartDate As Date = EndDate.AddMonths(-1)
    Dim YeatDate As Date = New Date()
    If i = 0 Then '如果是第一行
        dr("新水1_月用量")  = dr("新水_天用量") '
        dr("新水1_年用量") = dr("新水_天用量")
    Else
        Dim lastdate As Date = drs(i-1)("日期")
        Dim y1 As Integer = lastdate.year
        Dim m1 As Integer = lastdate.Month
        Dim d1 As Integer = lastdate.day
        y1 = IIF(m1=12 And d1>=26,y1+1,y1)
        If lastDate >= StartDate AndAlso lastDate < EndDate Then ' 如果和上一行是同月
            dr("新水1_月用量")  = dr("新水_天用量") + drs(i-1)("新水1_月用量")
        Else '如果和上一行不是同月
            dr("新水1_月用量")  = dr("新水_天用量")
        End If
        If y1 = y Then '如果和上一行同年
            dr("新水1_年用量") = dr("新水_天用量") + drs(i-1)("新水1_年用量")
        Else
            dr("新水1_年用量") = dr("新水_天用量")
        End If
    End If
Next
'DataTables("表a").ResumeRedraw()
MessageBox.Show("方法1耗时: " & (Date.Now - st).TotalSeconds & "秒")

[此贴子已经被作者于2013-9-8 11:42:01编辑过]

 回到顶部
帅哥哟,离线,有人找我吗?
有点酸
  5楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:五尾狐 帖子:1093 积分:6682 威望:0 精华:0 注册:2013/7/1 9:05:00
  发帖心情 Post By:2013/9/8 11:39:00 [只看该作者]

数据量越大,提速越多,可能会有上百倍。

相关知识来自:

http://www.foxtable.com/help/topics/2382.htm

http://www.foxtable.com/help/topics/2219.htm

 


 回到顶部