zoukankan      html  css  js  c++  java
  • 将两个DataTable合并成一个DataTable

    转载自 http://blog.csdn.net/wangxiaojia42121/article/details/53330464 谢谢

    //两个结构一样的DT合并
    DataTable DataTable1 = new DataTable();
    DataTable DataTable2 = new DataTable();
    DataTable newDataTable = DataTable1.Clone();

    object[] obj = new object[newDataTable.Columns.Count];
    for (int i = 0; i < DataTable1.Rows.Count; i++)
    {
        DataTable1.Rows[i].ItemArray.CopyTo(obj,0);
        newDataTable.Rows.Add(obj);
    }

    for (int i = 0; i < DataTable2.Rows.Count; i++)
    {
        DataTable2.Rows[i].ItemArray.CopyTo(obj,0);
        newDataTable.Rows.Add(obj);
    }

    //两个结构不同的DT合并
    /// <summary>
      /// 将两个列不同的DataTable合并成一个新的DataTable
      /// </summary>
      /// <param name="dt1">表1</param>
      /// <param name="dt2">表2</param>
      /// <param name="DTName">合并后新的表名</param>
      /// <returns></returns>
      private DataTable UniteDataTable( DataTable dt1 ,DataTable dt2 ,string DTName)
      { 
       DataTable dt3 = dt1.Clone();
       for( int i = 0 ;i < dt2.Columns.Count ;i ++ )
       {
        dt3.Columns.Add( dt2.Columns[i].ColumnName ) ;
       }
       object[] obj = new object[dt3.Columns.Count];
       
       for (int i = 0; i < dt1.Rows.Count; i++)
       {
        dt1.Rows[i].ItemArray.CopyTo(obj,0);
        dt3.Rows.Add(obj);
       }
          
       if( dt1.Rows.Count >= dt2.Rows.Count )
       {
        for( int i = 0 ;i < dt2.Rows.Count ;i++ )
        {
         for( int j = 0 ;j < dt2.Columns.Count ;j ++ )
         {
          dt3.Rows[i][j+dt1.Columns.Count] = dt2.Rows[i][j].ToString() ;
         }
        }
       }
       else
       {
        DataRow dr3 ;
        for( int i = 0 ;i < dt2.Rows.Count - dt1.Rows.Count ;i ++ )
        {
         dr3 = dt3.NewRow() ;
         dt3.Rows.Add( dr3 ) ;
        }
        for( int i = 0 ;i < dt2.Rows.Count ;i++ )
        {
         for( int j = 0 ;j < dt2.Columns.Count ;j ++ )
         {
          dt3.Rows[i][j+dt1.Columns.Count] = dt2.Rows[i][j].ToString() ;
         }
        }
       }
       dt3.TableName = DTName ; //设置DT的名字
       return dt3 ;
      }

    再三须慎意,第一莫欺心
  • 相关阅读:
    远程桌面工具mRemoteNG与Tsmmc
    敏感性Sensitivity和特异性Specificity的说明
    React教程:4 个 useState Hook 示例
    React Hooks究竟是什么呢?
    一步一步搭建前端监控系统:如何监控资源加载错误?
    Promise的三兄弟:all(), race()以及allSettled()
    JavaScript中this究竟指向什么?
    编译器与Debug的传奇:Grace Murray Hopper小传
    21个React开发神器
    8种常见数据结构及其Javascript实现
  • 原文地址:https://www.cnblogs.com/otsf/p/8520590.html
Copyright © 2011-2022 走看看