Foxtable(狐表)用户栏目专家坐堂 → 当表A的C列等于“出售”时,D列会自动输入“成功”,否则则为空


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

主题:当表A的C列等于“出售”时,D列会自动输入“成功”,否则则为空

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


加好友 发短信
等级:三尾狐 帖子:715 积分:6677 威望:0 精华:0 注册:2016/6/27 17:56:00
当表A的C列等于“出售”时,D列会自动输入“成功”,否则则为空  发帖心情 Post By:2017/7/9 19:52:00 [只看该作者]

老师,请问下,当表A的C列等于“出售”时,D列会自动输入“成功”,否则则为空,代码要怎么写,谢谢!

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


加好友 发短信
等级:版主 帖子:85326 积分:427815 威望:0 精华:5 注册:2012/10/18 22:13:00
  发帖心情 Post By:2017/7/9 20:43:00 [只看该作者]

If e.DataCol.Name = "C" Then

    If e.newvalue = "出售" Then

        e.DataRow("D") = "成功"

    Else

        e.DataRow("D") = Nothing

    End If

End If


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


加好友 发短信
等级:三尾狐 帖子:715 积分:6677 威望:0 精华:0 注册:2016/6/27 17:56:00
  发帖心情 Post By:2017/7/12 16:16:00 [只看该作者]

老师,上面的代码要重置列后才会更新,我有几万行,重置直接卡死,怎样可以不重置就会认到数据变化

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


加好友 发短信
等级:二尾狐 帖子:573 积分:4247 威望:0 精华:0 注册:2015/5/13 8:32:00
  发帖心情 Post By:2017/7/12 16:26:00 [只看该作者]

可以把 D列 变成 表达式
IIF([C]='出售','成功','')


或者用  表属性里面的

DrawCell


If e.Col.Name = "D" Then
    If e.Row.IsNull("C") Then Return
    If e.Row("C")="出售" Then e.text="成功"
End If


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


加好友 发短信
等级:超级版主 帖子:109678 积分:558082 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2017/7/12 16:41:00 [只看该作者]

如果是2楼的方法,不重置不行的。

或者可以使用sql直接更新后台数据。

或者
DataTables("A表").ReplaceFor("D","成功","C='出售'")
DataTables("A表").ReplaceFor("D",Nothing,"C<>'出售'")
然后重新加载数据

 回到顶部