如何合并两个结构相同的DataTable

时间:2021-07-12 16:19:09

今天遇到了一个情况,就是从一张数据表中读取几个符合条件1的客户的信息,然后再读取几个符合条件2的客户的信息,最后显示出来.因为前后两次数据的客户信息的结构是完全相同的,所以干脆合并成一个DataTable再赋值给GridView好了.写了个函数.

 /// <summary>
        /// 合并两个相同的DataTable,返回合并后的结果
        /// </summary>
        /// <param name="dt1"></param>
        /// <param name="dt2"></param>
        /// <returns></returns>
        public DataTable CombineTheSameDatatable(DataTable dt1, DataTable dt2)
        {
            if (dt1.Rows.Count == 0 && dt2.Rows.Count == 0)
            {
                return new DataTable();
            }
            if (dt1.Rows.Count == 0)
            {
                return dt2;
            }
            if (dt2.Rows.Count == 0)
            {
                return dt1;
            }
            DataSet ds = new DataSet();
            ds.Tables.Add(dt1.Copy());
            ds.Merge(dt2.Copy());
            return ds.Tables[0];
        }

由于对C#的理解有限,所以不明白为什么用dt1==null不能正确判断空表,所以用了数行的方法.还望高人能指点一二.