比较c#中的两个数据表

时间:2011-05-31 11:52:06

标签: c#

比较两个数据表的最佳方法是什么。我填充两个数据表读取两个不同的xml,现在我需要比较并返回datatable.my比较逻辑的差异

private DataTable CompareDataTables(DataTable dtFirst, DataTable dtSecond)
    {
        int result = 0;
        bool flag = false;
        DataTable dtNoRows = new DataTable();
        dtNoRows.Columns.Add("Result");

        DataTable dtDiff = new DataTable();
        dtDiff.Columns.Add("Field Name");
        dtDiff.Columns.Add("Old Value");
        dtDiff.Columns.Add("New Value");
        DataRow dr = null;
        if (dtFirst.Columns.Count == dtSecond.Columns.Count)
        {
            for (int i = 0; i <= dtFirst.Columns.Count - 1; i++)
            {
                try
                {
                    DateTime.Parse(dtFirst.Rows[0][dtFirst.Columns[i].ColumnName.ToString()].ToString().Trim());
                    flag = true;
                }
                catch (Exception ex)
                {
                    flag = false;
                }

                if (!flag)
                {
                    if (dtFirst.Rows[0][dtFirst.Columns[i].ColumnName.ToString()].ToString().Trim().ToUpper() != dtSecond.Rows[0][dtSecond.Columns[i].ColumnName.ToString()].ToString().Trim().ToUpper())
                    {
                        dr = dtDiff.NewRow();
                        dr["Field Name"] = dtFirst.Columns[i].ColumnName.ToString();
                        dr["Old Value"] = dtFirst.Rows[0][dtFirst.Columns[i].ColumnName.ToString()].ToString().Trim();
                        dr["New Value"] = dtSecond.Rows[0][dtSecond.Columns[i].ColumnName.ToString()].ToString().Trim();
                        dtDiff.Rows.Add(dr);
                    }
                }
                else
                {
                    result = DateTime.Compare(DateTime.Parse(dtFirst.Rows[0][dtFirst.Columns[i].ColumnName.ToString()].ToString()), DateTime.Parse(dtSecond.Rows[0][dtSecond.Columns[i].ColumnName.ToString()].ToString()));
                    if (result != 0)
                    {
                        dr = dtDiff.NewRow();
                        dr["Field Name"] = dtFirst.Columns[i].ColumnName.ToString();
                        dr["Old Value"] = DateTime.Parse(dtFirst.Rows[0][dtFirst.Columns[i].ColumnName.ToString()].ToString().Trim()).ToString("MM/dd/yyyy") + " - " + DateTime.Parse(dtFirst.Rows[0][dtFirst.Columns[i].ColumnName.ToString()].ToString().Trim()).ToString("hh:mm:ss");
                        dr["New Value"] = DateTime.Parse(dtSecond.Rows[0][dtSecond.Columns[i].ColumnName.ToString()].ToString().Trim()).ToString("MM/dd/yyyy") + " - " + DateTime.Parse(dtSecond.Rows[0][dtSecond.Columns[i].ColumnName.ToString()].ToString().Trim()).ToString("hh:mm:ss");
                        dtDiff.Rows.Add(dr);

                    }
                    flag = false;
                }
            }
        }
        return dtDiff;
    }

我的代码工作正常,但我需要有最好的出路。请指导我。

2 个答案:

答案 0 :(得分:0)

您可以使用LINQ比较表值(两个表必须具有相同的结构)

bool flag = false;
if (dtFirst.Columns.Count == dtSecond.Columns.Count)
{
    for (int i = 0; i <= dtFirst.Columns.Count - 1; i++)
    {
        String colName = dtFirst.Columns[i].ColumnName;
        var colDataType = dtFirst.Columns[i].DataType.GetType();
        var colValue = dtFirst.Columns[i];
        flag = dtSecond.AsEnumerable().Any(T => typeof(T).GetProperty(colName).GetValue(T, typeof(colDataType)) == colValue);
    }
}

答案 1 :(得分:0)

var qry1 = dtDuplicate.AsEnumerable().Select(a => new { SchoolID = a["SchoolMID"].ToString()});
var qry2 = dsValadateSchoolInfo.Tables[1].AsEnumerable().Select(b => new { SchoolID = ["SchoolMID"].ToString() });

var exceptAB = qry1.Except(qry2);

DataTable dtMisMatch = (from a in dtDuplicate.AsEnumerable()
                        join ab in exceptAB on a["SchoolMID"].ToString() equals ab.SchoolID
                        select a).CopyToDataTable();