欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C# 實(shí)現(xiàn)Table的Merge,Copy和Clone

 更新時(shí)間:2020年12月11日 09:37:38   作者:農(nóng)碼一生  
這篇文章主要介紹了C# 實(shí)現(xiàn)Table的Merge,Copy和Clone,幫助大家更好的利用c#處理文件,感興趣的朋友可以了解下

C#實(shí)現(xiàn)的對(duì)兩個(gè)Table進(jìn)行Merge,兩表必須存在至少一個(gè)公共欄位作為連接項(xiàng),否則連接就失去了意義。如下是對(duì)兩個(gè)table進(jìn)行Merge的詳細(xì)代碼:

private void button1_Click(object sender, EventArgs e)//Button點(diǎn)擊觸發(fā)事件
    {
      #region Table的Merge
      DataTable dt = new DataTable();

      DataTable dt1 = new DataTable();//創(chuàng)建Table1
      dt1.Columns.Add("ID", typeof(string));
      dt1.Columns.Add("NAME",typeof(string));
      dt1.Columns.Add("AGE", typeof(int));
      dt1.Columns.Add("SEX", typeof(string));

      dt1.PrimaryKey = new DataColumn[] { dt1.Columns["ID"]};
      for (int i = 0; i < 5; i++)
      {
        DataRow dr = dt1.NewRow();
        dr["ID"] = "00" + i.ToString();
        dr["NAME"] = "00-" + i.ToString();
        dr["AGE"] = 15 + i;
        dr["SEX"] = "M";
        dt1.Rows.Add(dr);

      }
      dt = dt1;

      DataTable dt2 = new DataTable();//創(chuàng)建Table2
      dt2.Columns.Add("ID", typeof(string));
      dt2.Columns.Add("NAME", typeof(string));
      dt2.Columns.Add("Course",typeof(string));
      dt2.Columns.Add("Score",typeof(int));

      dt2.PrimaryKey = new DataColumn[] { dt2.Columns["ID"] };
      for (int i = 0; i < 5; i++)
      {
        DataRow dr = dt2.NewRow();
        dr["ID"] = "00" + i.ToString();
        dr["NAME"] = "00-" + i.ToString();
        dr["Course"] ="C#";
        dr["Score"] = i + 80;
        dt2.Rows.Add(dr);
      }
      dt = dt2;
      dt1.Merge(dt2);

      //Copy
      var table1 = dt1.Copy();//Copy,復(fù)制表的結(jié)構(gòu)以及數(shù)據(jù)
      //添加新的一行
      DataRow dr1 = table1.NewRow();
      dr1["ID"] = "005";
      dr1["NAME"] = "00-5";
      dr1["AGE"] = 15;
      dr1["SEX"] = "F";
      table1.Rows.InsertAt(dr1,2);//表的指定位置插入新增加的一行   
       
      table1.Columns.Add(new DataColumn() { ColumnName = "Memo", DataType = typeof(string) });//默認(rèn)插入到最後一列
      table1.Columns["Memo"].SetOrdinal(0);//把插入的列移動(dòng)到第一行

      int memoIndex = table1.Columns.IndexOf("Memo");//獲取列的位置信息
      var isContainName = table1.Columns.Contains("NAME");//判斷table中是否存在某列

      List<string> columnsNameList = new List<string>();//遍歷獲取table的所有列名
      foreach (DataColumn col in table1.Columns)
      {
        columnsNameList.Add(col.ColumnName);
      }

      table1.Columns.RemoveAt(memoIndex);//通過(guò)列名的索引進(jìn)行移除
      table1.Columns.RemoveAt(2);//通過(guò)列名的索引進(jìn)行移除

      table1.Columns.Remove("SEX");//通過(guò)列名進(jìn)行移除,建議使后者
      

      string[] name = new string[table1.Rows.Count];//方法一:對(duì)表中的數(shù)據(jù)進(jìn)行遍歷輸出
      string[] id = new string[table1.Rows.Count];
      for (int i = 0; i < table1.Rows.Count; i++)
      {
        name[i] = table1.Rows[i]["NAME"].ToString();
        id[i] = table1.Rows[i]["ID"].ToString();
      }
           
      table1.Clear();//清空表中的數(shù)據(jù)

      //Clone
      var table2 = dt2.Clone();//Clone,復(fù)制表的結(jié)構(gòu)、約束信息

      #endregion

    }

以上就是C# 實(shí)現(xiàn)Table的Merge,Copy和Clone的詳細(xì)內(nèi)容,更多關(guān)于c# table Merge的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • C#常用正則驗(yàn)證函數(shù)示例

    C#常用正則驗(yàn)證函數(shù)示例

    這篇文章主要介紹了C#常用正則驗(yàn)證函數(shù),舉例分析了C#針對(duì)IP驗(yàn)證、價(jià)格驗(yàn)證及正整數(shù)驗(yàn)證的相關(guān)操作技巧,需要的朋友可以參考下
    2017-01-01
  • C#中的位操作小結(jié)

    C#中的位操作小結(jié)

    在C#中位操作同C的位操作沒(méi)有什么區(qū)別,位操作的速度相對(duì)較快,而且如果熟練的話,處理起來(lái)也相對(duì)方便,特別是在一些權(quán)限等相關(guān)的設(shè)置中
    2014-01-01
  • Unity EasyTouch搖桿插件使用示例詳解

    Unity EasyTouch搖桿插件使用示例詳解

    這篇文章主要介紹了Unity EasyTouch搖桿插件使用,這套插件還支持雙指縮放,滑動(dòng),手指畫(huà)圈,點(diǎn)擊,多指觸碰,拖拽等,通過(guò)示例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2021-10-10
  • C#表達(dá)式樹(shù)Expression基礎(chǔ)講解

    C#表達(dá)式樹(shù)Expression基礎(chǔ)講解

    這篇文章介紹了C#表達(dá)式樹(shù)Expression和基本用法,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-12-12
  • C#身份證識(shí)別相關(guān)技術(shù)功能詳解

    C#身份證識(shí)別相關(guān)技術(shù)功能詳解

    這篇文章主要介紹了C#身份證識(shí)別相關(guān)技術(shù)詳解,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-07-07
  • C#使用Socket快速判斷數(shù)據(jù)庫(kù)連接是否正常的方法

    C#使用Socket快速判斷數(shù)據(jù)庫(kù)連接是否正常的方法

    這篇文章主要介紹了C#使用Socket快速判斷數(shù)據(jù)庫(kù)連接是否正常的方法,涉及C#中socket操作的相關(guān)技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2015-04-04
  • C#波形圖控件制作示例程序

    C#波形圖控件制作示例程序

    這篇文章主要介紹了C#波形圖控件的制作方法,大家參考使用
    2013-11-11
  • c#利用Grahics進(jìn)行圖片裁剪

    c#利用Grahics進(jìn)行圖片裁剪

    這兩天做了一個(gè)圖片對(duì)比工具,里面要處理兩張大的圖片,所以要對(duì)圖片先進(jìn)行裁剪,下面看看我的方法吧
    2013-12-12
  • Json操作庫(kù)DynamicJson使用指南

    Json操作庫(kù)DynamicJson使用指南

    本文給大家分享的是專(zhuān)門(mén)為.NET程序員開(kāi)發(fā)的Json操作庫(kù)DynamicJson,其源碼非常簡(jiǎn)單,僅僅只有400行代碼,一個(gè)對(duì)應(yīng)的class類(lèi),目前只支持.NET 4.0以上的.NET Framework。
    2016-09-09
  • c#和avascript加解密之間的互轉(zhuǎn)代碼分享

    c#和avascript加解密之間的互轉(zhuǎn)代碼分享

    這篇文章主要介紹了c#和Javascript間互轉(zhuǎn)的Xxtea加解密代碼,需要的朋友可以參考下
    2014-02-02

最新評(píng)論