Foxtable(狐表)用户栏目专家坐堂 → [求助]刷新数据


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

主题:[求助]刷新数据

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


加好友 发短信
等级:五尾狐 帖子:1141 积分:11272 威望:0 精华:0 注册:2017/9/26 16:30:00
[求助]刷新数据  发帖心情 Post By:2021/4/29 21:59:00 [只看该作者]

蓝老师好!
遇到下面的问题,刷新数据后弹出的的数量有时是对的,有时是“0”,不知道是什么原因?
逻辑如下:
单词表的逻辑列[通过]列,是根据不同的练习人,查询在“练习日志”表格中的[通过单词]列,记录的单词来赋值的。请看代码及注释:

'获取通过信息
Dim Sum As Double   ’预设更新数量
Dim dr As DataRow
dr = DataTables("设置表").sqlFind("用户 = '" & _UserName & "'")
If dr IsNot Nothing Then '如果找到的话
    DataTables(dr("默认阶段")).ReplaceFor("通过", False)   '先清除通过勾选
    
    Dim str As String =""     '获取该用户通过的单词
    Dim dr0s As List(Of DataRow)
    dr0s = DataTables("练习日志").SQLSelect("[练习人] = '" & _UserName & "' And [练习年份]= '" &  Date.Today.Year & "年'")   '本年通过的单词
    For Each dr0 As DataRow In dr0s
        str += dr0("通过单词") & "、"
    Next
    
    Dim Values() As String    '集合去重到新集合
    Values = str.replace("、、","、").Trim("、").split("、")
    Dim lts As New List(Of String)
    Dim lt As String
    For Index As Integer = 0 To Values.Length - 1
        If lts.Contains(Values(Index)) = False Then
            lts.add(Values(Index))
        End If
    Next
    
    For Each lt In lts   '新集合的值遍历,为逻辑列赋值
        DataTables(dr("默认阶段")).SQLReplaceFor("通过", 1, "单词 = '" & lt.Replace("'","''") & "'")
    Next
End If

Sum =  DataTables(dr("默认阶段")).Compute("Count(通过)", "通过 = 1")
DataTables(dr("默认阶段")).LoadFilter = ""
DataTables(dr("默认阶段")).Load

msgbox("刷新完毕!" & vbcrlf &  "共通过" & Sum & "个单词。")


图片点击可在新窗口打开查看此主题相关图片如下:截屏图片 (1).jpg
图片点击可在新窗口打开查看


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


加好友 发短信
等级:超级版主 帖子:110574 积分:562760 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2021/4/29 22:25:00 [只看该作者]

ReplaceFor改为sqlReplaceFor

Compute改为sqlCompute

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


加好友 发短信
等级:五尾狐 帖子:1141 积分:11272 威望:0 精华:0 注册:2017/9/26 16:30:00
  发帖心情 Post By:2021/4/29 22:47:00 [只看该作者]

谢谢!

[此贴子已经被作者于2021/4/29 22:59:59编辑过]

 回到顶部