Foxtable(狐表)用户栏目专家坐堂 → 这段代码我只想product表里添加一条记录 结果是添加了两个


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

主题:这段代码我只想product表里添加一条记录 结果是添加了两个

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


加好友 发短信
等级:贵宾 帖子:35433 积分:178524 威望:0 精华:3 注册:2013/3/30 16:36:00
  发帖心情 Post By:2015/5/5 14:00:00 [显示全部帖子]

代码发出来

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


加好友 发短信
等级:贵宾 帖子:35433 积分:178524 威望:0 精华:3 注册:2013/3/30 16:36:00
  发帖心情 Post By:2015/5/5 14:06:00 [显示全部帖子]

你没有判断列名. 好像之前都提醒过你好几次.

DataColChanged 等事件一定要加入列名判断.

你改变哪个列才触发这个事件一定要判断好.否则你更改列其他列的值,就会一直触发多次.  

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


加好友 发短信
等级:贵宾 帖子:35433 积分:178524 威望:0 精华:3 注册:2013/3/30 16:36:00
  发帖心情 Post By:2015/5/5 14:23:00 [显示全部帖子]

if e.datacol.name = "cord" then

If e.DataRow.isnull("cord")=False Then
       Dim dr As DataRow
        dr = DataTables("product").Find("[cord] = '" & e.NewValue & "'")
        If dr IsNot Nothing Then '如果找到了同名的产品行,也就是dr不是Nothing
            e.DataRow("name") = dr("shangpinming")
            e.DataRow("markprice") = dr("markprice") 
            
Else

e.DataRow("nnn")=e.DataRow("name")     

If e.DataRow.isnull("nnn")=False And dr Is Nothing Then
Dim idxs As String = ""
For i As Integer = Tables("rukudanhao.rukudan").TopPosition To Tables("rukudanhao.rukudan").BottomPosition
    idxs &= Tables("rukudanhao.rukudan").Rows(i)("_Identify")
Next

Dim f As New Filler
f.Filter = "_Identify in (" & idxs.Trim(",") & ")"
f.SourceTable = DataTables("rukudan") '指定数据来源
f.SourceCols = "cord,name,markprice" '指定数据来源列
f.DataTable = DataTables("product") '指定数据接收表
f.DataCols = "cord,shangpinming,markprice" '指定数据接收列
f.Fill() '填充数据
DataTables("product").save()
End If
End If

end if
end If


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


加好友 发短信
等级:贵宾 帖子:35433 积分:178524 威望:0 精华:3 注册:2013/3/30 16:36:00
  发帖心情 Post By:2015/5/5 14:35:00 [显示全部帖子]

数据反而添加了?

 回到顶部