Foxtable(狐表)用户栏目专家坐堂 → 如何实现针对不同的客户显示上次售价?


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

主题:如何实现针对不同的客户显示上次售价?

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


加好友 发短信
等级:幼狐 帖子:175 积分:1646 威望:0 精华:0 注册:2015/6/10 13:50:00
如何实现针对不同的客户显示上次售价?  发帖心情 Post By:2015/7/17 18:28:00 [只看该作者]

想实现的功能:在订单界面输入客户和产品后,价格列自动填入该客户上次订单的售价
Dim dr As DataRow
Dim pm As String = Tables("订单明细").Current.DataRow("品名")
Dim kh As String = Tables("订单明细").Current.DataRow("客户名称")
dr = DataTables("订单明细").Find(".品名 = pm & .客户名称 = kh ","日期 Desc")
If dr IsNot Nothing Then 
    Tables("订单明细").Current.DataRow("价格") = dr("价格")
End If
另一种也是不行:
If e.DataCol.Name = "客户名称" Or e.DataCol.Name = "品名" Then
    Dim dr As DataRow
    Dim Filter As String
    Filter = "[客户名称] = '" & e.DataRow("客户名称") & "' And [品名] = '" & e.DataRow("品名") & "'"
    dr = DataTables("订单明细").Find(Filter ,"日期 Desc")
    If dr IsNot Nothing Then 
        e.DataRow("价格") = dr("价格")
    End If
End If
还有个疑问:当代码查找到需要的行时,current是当前需要输入的行,还是查找到的行?
[此贴子已经被作者于2015/7/17 20:37:25编辑过]

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


加好友 发短信
等级:管理员 帖子:47449 积分:251065 威望:0 精华:91 注册:2008/6/17 17:14:00
  发帖心情 Post By:2015/7/18 10:27:00 [只看该作者]

第二种方法应该可以,不过应该稍微改一下,排除掉本行:

If e.DataCol.Name = "客户名称" Or e.DataCol.Name = "品名" Then
    Dim dr As DataRow
    Dim Filter As String
    Filter = "[客户名称] = '" & e.DataRow("客户名称") & "' And [品名] = '" & e.DataRow("品名") & "' And [_Identify] <> " & e.DataRow("_Identify")
    dr = DataTables("订单明细").Find(Filter ,"日期 Desc")
    If dr IsNot Nothing Then 
        e.DataRow("价格") = dr("价格")
    End If
End If

如果还不行,做个例子发上来。

 回到顶部