Foxtable(狐表)用户栏目专家坐堂 → 公式如何修改


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

主题:公式如何修改

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


加好友 发短信
等级:婴狐 帖子:40 积分:376 威望:0 精华:0 注册:2012/1/3 17:14:00
公式如何修改  发帖心情 Post By:2012/1/19 20:59:00 [只看该作者]

If e.DataCol.Name = "选择" Then
    If e.DataRow("选择") = True Then
        Dim nma() As String = {"单位","商品类别","商品代码","商品名称","仓库名称","仓位","日期","进库_折扣","进库_数量","进库_单价","进库_金额","规格","等级"} 'A表数据来源列
        Dim nmb() As String = {"单位","商品类别","商品代码","商品名称","仓库名称","仓位","日期","进库_折扣","进库_数量","进库_单价","进库_金额","规格","等级"} 'B表数据来源列        Dim dr As DataRow = DataTables("库存表").AddNew
       Dim dr As DataRow = DataTables("库存表").AddNew
        For i As Integer = 0 To nma.Length - 1
            dr(nmb(i)) = e.DataRow(nma(i))
        Next
        For Each dc As DataCol In DataTables("库存表").DataCols
            If dc.name ="id" Then
                dr("id") =e.DataRow("_identify")
            Else
                dr("商品类别") = e.DataRow("商品类别")

                dr("商品名称") = e.DataRow("商品名称")
                dr("商品代码") = e.DataRow("商品代码")
                dr("规格") =e.DataRow("规格")
                dr("等级") =e.DataRow("等级")
                dr("单位") = e.DataRow("单位")
                 dr("商品名称") =e.DataRow("商品名称")
                dr("仓位") =e.DataRow("仓位")
                dr("日期") = e.DataRow("日期")
                dr("进库_折扣") =e.DataRow("进库_折扣")
                dr("进库_数量") =e.DataRow("进库_数量")
                dr("进库_单价") = e.DataRow("进库_单价")
                dr("进库_金额") = e.DataRow("进库_金额")
            End If
        Next
    Else
        Dim tr As DataRow =DataTables("库存表").find("id ="& e.DataRow("id"))
        If tr IsNot Nothing Then
            tr.delete()
        End If
    End If
End If

以上是表DataColChanged公式,"选择“列打算不要了

If e.DataCol.Name = "选择" Then
    If e.DataRow("选择") = True Then

这两句去掉,我想直接在窗口的“保存”按钮把库存明细表的公式保存到库存表,同时如果明细表内容有变动,库存表同样发生相应变动,公式如何修改?


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


加好友 发短信
等级:管理员 帖子:47448 积分:251054 威望:0 精华:91 注册:2008/6/17 17:14:00
  发帖心情 Post By:2012/1/20 8:50:00 [只看该作者]

没有人这样设计修通的,数据冗余,维护困难,编码难度大幅增加。

同样的数据,应该只出现在一个地方。

 

还有你原来的公式,完全重复了,有一段是多余的,应该:

 

If e.DataCol.Name = "选择" Then
    If e.DataRow("选择") = True Then
        Dim nma() As String = {"单位","商品类别","商品代码","商品名称","仓库名称","仓位","日期","进库_折扣","进库_数量","进库_单价","进库_金额","规格","等级"} 'A表数据来源列
        Dim nmb() As String = {"单位","商品类别","商品代码","商品名称","仓库名称","仓位","日期","进库_折扣","进库_数量","进库_单价","进库_金额","规格","等级"} 'B表数据来源列        Dim dr As DataRow = DataTables("库存表").AddNew
        Dim dr As DataRow = DataTables("库存表").AddNew
        For i As Integer = 0 To nma.Length - 1
            dr(nmb(i)) = e.DataRow(nma(i))
        Next
        dr("id") =e.DataRow("_identify")
    Else
        Dim tr As DataRow =DataTables("库存表").find("id ="& e.DataRow("id"))
        If tr IsNot Nothing Then
            tr.delete()
        End If
    End If
End If


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


加好友 发短信
等级:婴狐 帖子:40 积分:376 威望:0 精华:0 注册:2012/1/3 17:14:00
  发帖心情 Post By:2012/1/20 12:12:00 [只看该作者]

以上是表DataColChanged公式,"选择“列只作为触发事件达到复制效果,打算不要了以下两句

If e.DataCol.Name = "选择" Then
    If e.DataRow("选择") = True Then

这两句去掉,我想直接在窗口的“保存”按钮把库存明细表的公式保存到库存表,同时如果明细表内容有变动,库存表同样发生相应变动,公式如何修改?

我是刚接触孤表的新手,好多地方不懂,请指教



 回到顶部