简体   繁体   English

比较 c# 中的两个数据表

[英]compare two datatable in c#

what would be the best way to compare two data table.比较两个数据表的最佳方法是什么。 i populate two data table reading two different xml and now i need to compare and return the difference in terms of datatable.my compare logic was我填充两个数据表,读取两个不同的 xml,现在我需要比较并返回数据表方面的差异。我的比较逻辑是

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;
    }

my code is working fine but i need to the is there any best way out.我的代码工作正常,但我需要有什么最好的出路。 please guide me.请指导我。

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();

you can use LINQ to comparing tables values(two table must have the same structure)您可以使用 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);
    }
}

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM