Foxtable(狐表)用户栏目专家坐堂 → [求助]关于微整数值不显示的问题


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

主题:[求助]关于微整数值不显示的问题

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


加好友 发短信
等级:童狐 帖子:253 积分:2573 威望:0 精华:0 注册:2016/8/8 9:50:00
[求助]关于微整数值不显示的问题  发帖心情 Post By:2020/2/27 12:50:00 [只看该作者]


请教老师,A表的微整数值字段为0时,我想通过DataColChanged事件让B表相关微整数值字段也显示为0,但是B表却显示为“”,该如何解决?
[此贴子已经被作者于2020/2/27 12:55:32编辑过]

 回到顶部
帅哥,在线噢!
有点蓝
  2楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:111393 积分:567029 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2020/2/27 14:26:00 [只看该作者]

写了什么代码,贴出来

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


加好友 发短信
等级:童狐 帖子:253 积分:2573 威望:0 精华:0 注册:2016/8/8 9:50:00
  发帖心情 Post By:2020/2/27 14:53:00 [只看该作者]

Dim dr As DataRow
dr = DataTables("表B").Find("第一列 ='" & e.DataRow("第一列") & "' and 第二列 =#" & e.DataRow("第二列") & "#")

If dr IsNot Nothing Then
    If e.DataRow("第三列") = Nothing Then
        dr("第三列") = Nothing
    ElseIf e.DataRow("第三列") <> Nothing Then
        dr("第三列") = e.DataRow("第三列")
    End If
ElseIf dr Is Nothing Then
    Dim t = Tables("表B").AddNew
    t("第一列") = e.DataRow("第一列")
    t("第二列") = e.DataRow("第二列")
    t("第三列") = e.DataRow("第三列")
End If
 下载信息  [文件大小:   下载次数: ]
图片点击可在新窗口打开查看点击浏览该文件:示例.table



 回到顶部
帅哥,在线噢!
有点蓝
  4楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:111393 积分:567029 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2020/2/27 15:15:00 [只看该作者]

问题1,先看看:http://www.foxtable.com/webhelp/topics/1522.htm

Select Case e.DataCol.Name
    Case  "第一列","第二列"
        If e.DataRow.IsNull("第一列") = False AndAlso e.DataRow.IsNull("第二列") = False  Then
            Dim dr As DataRow
            dr = DataTables("表B").Find("第一列 ='" & e.DataRow("第一列") & "' and 第二列 =#" & e.DataRow("第二列") & "#")
            
            If dr Is Nothing Then
                dr = DataTables("表B").AddNew
                dr("第一列") = e.DataRow("第一列")
                dr("第二列") = e.DataRow("第二列")
            End If
            dr("第三列") = e.DataRow("第三列")
        End If
End Select

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


加好友 发短信
等级:童狐 帖子:253 积分:2573 威望:0 精华:0 注册:2016/8/8 9:50:00
  发帖心情 Post By:2020/2/27 15:34:00 [只看该作者]


谢谢老师,把上述代码改成:
Select Case e.DataCol.Name
    Case  "第一列","第二列","第三列"
        If e.DataRow.IsNull("第一列") = False AndAlso e.DataRow.IsNull("第二列") = False  Then
            Dim dr As DataRow
            dr = DataTables("表B").Find("第一列 ='" & e.DataRow("第一列") & "' and 第二列 =#" & e.DataRow("第二列") & "#")
            
            If dr Is Nothing Then
                dr = DataTables("表B").AddNew
                dr("第一列") = e.DataRow("第一列")
                dr("第二列") = e.DataRow("第二列")
            End If
            dr("第三列") = e.DataRow("第三列")
        End If
End Select

问题解决了。

但如果把A表的第三列数字删掉后,B表的第三列会显示为0,这时能否让B表第三列显示为“”;只有当A表第三列输入0时,B表第三列才显示为0
[此贴子已经被作者于2020/2/27 15:35:06编辑过]

 回到顶部
帅哥,在线噢!
有点蓝
  6楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:111393 积分:567029 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2020/2/27 16:00:00 [只看该作者]

if e.DataRow.isnull("第三列")
dr("第三列") = nothing
else
dr("第三列") = e.DataRow("第三列")
endif

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


加好友 发短信
等级:童狐 帖子:253 积分:2573 威望:0 精华:0 注册:2016/8/8 9:50:00
  发帖心情 Post By:2020/2/27 16:07:00 [只看该作者]


谢谢老师!

 回到顶部