以文本方式查看主题

-  Foxtable(狐表)  (http://foxtable.net/bbs/index.asp)
--  专家坐堂  (http://foxtable.net/bbs/list.asp?boardid=2)
----  如何快速判断同表结构的两表数据有哪些字段值不同?  (http://foxtable.net/bbs/dispbbs.asp?boardid=2&id=66166)

--  作者:lmlptj
--  发布时间:2015/3/31 14:48:00
--  如何快速判断同表结构的两表数据有哪些字段值不同?
A、B两表结构完全相同,如何用代码实现快速判断哪些字段值不同,如果遇到字段相同而值不同,则将新旧值结果写到另外一个表中??脑袋都想大了!
麻烦各位老师指点!谢谢啦!

--  作者:有点甜
--  发布时间:2015/3/31 14:54:00
--  
For Each dr As DataRow In DataTables("表A").Select("")
    Dim fdr As DataRow = DataTables("表B").Find("第一列 = \'" & dr("第一列") & "\'")
    If fdr IsNot Nothing Then
        For Each dc As DataCol In DataTables("表A").DataCols
            If dr(dc.Name) <> fdr(dc.Name) Then
                Dim ndr As DataRow = DataTables("表C").AddNew
                ndr("第一列") = dr("第一列")
                ndr("第二列") = dc.name
                ndr("第三列") = dr(dc.name)
                ndr("第四列") = fdr(dc.name)
            End If
        Next
    End If
Next

--  作者:Bin
--  发布时间:2015/3/31 14:55:00
--  
既然表结构相同,又怎么会字段不相同?
--  作者:lmlptj
--  发布时间:2015/3/31 15:00:00
--  
就是比较字段的新旧值!看作了哪些改动,以便核对数据的正确性!
[此贴子已经被作者于2015/3/31 15:01:34编辑过]

--  作者:有点甜
--  发布时间:2015/3/31 15:02:00
--  

 看2楼,参考代码去写