C#實現的Table的Merge,以及實現Table的Copy和Clone

来源:https://www.cnblogs.com/wml-it/archive/2020/01/17/12204838.html

C#實現的對兩個Table進行Merge,兩表必須存在至少一個公共欄位作為連接項,否則連接就失去了意義。如下是對兩個table進行Merge的詳細代碼: private void button1_Click(object sender, EventArgs e)//Button點擊觸發事件 { #r ...


C#實現的對兩個Table進行Merge,兩表必須存在至少一個公共欄位作為連接項,否則連接就失去了意義。如下是對兩個table進行Merge的詳細代碼:

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

            DataTable dt1 = new DataTable();//創建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();//創建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,複製表的結構以及數據
            //添加新的一行
            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) });//默認插入到最後一列
            table1.Columns["Memo"].SetOrdinal(0);//把插入的列移動到第一行

            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);//通過列名的索引進行移除
            table1.Columns.RemoveAt(2);//通過列名的索引進行移除

            table1.Columns.Remove("SEX");//通過列名進行移除,建議使後者
           

            string[] name = new string[table1.Rows.Count];//方法一:對錶中的數據進行遍歷輸出
            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();//清空表中的數據

            //Clone
            var table2 = dt2.Clone();//Clone,複製表的結構、約束信息

            #endregion

        }

您的分享是我們最大的動力!

更多相關文章
  • C#實現的Check Password,並根據輸錯密碼的次數分情況鎖定賬戶:如果輸入錯誤3次,登錄賬戶鎖定5分鐘並提示X點X分後重試登錄。如果5分鐘後再次輸入,累計輸入錯誤密碼累計達到5次。則賬戶會被永久鎖定,需聯繫系統管理員進行把資料庫中的輸入錯誤的次數(errorcount)進行清零解鎖才能登陸 ...
  • [TOC] MVC "MVC 維基百科,自由的百科全書" MVC 是軟體工程的一種軟體架構模式,它不是具體的技術,而是一種代碼分層的理念,主要體現了職責分離原則。 M Model 模型 V View 視圖 C Controller 控制器 對 MVC 的誤解及緣由 誤解:頁面視圖 = View ,E ...
  • 簡介 Orleans用起來的確很爽,更爽的是咱們有能監控它的工具。 " OrleansDashboard " 這個工具是一個可視化的Silo監控工具,Silo和Grain的活躍狀態一目瞭然,各個介面的響應速度也可以很清晰的統計到。 安裝 使用NuGet引用 然後修改 的配置,添加Dashboard: ...
  • Teigha中實體旋轉 代碼: using (var trans = database.TransactionManager.StartTransaction()) { Entity ent = trans.GetObject(entityId, OpenMode.ForWrite) asEntit ...
  • 什麼是AutoMapper?AutoMapper是一個簡單的小型庫,用於解決一個看似複雜的問題 - 擺脫將一個對象映射到另一個對象的代碼。這種類型的代碼是相當沉悶和無聊的寫,所以為什麼不發明一個工具來為我們做? 我們來看看在.netcore3.1中怎樣使用AutoMapper9.0。 Profile ...
  • 程式處理存放圖片的幾種方式 我的理解有4個: 1:放在項目本身得文件夾中,直接部署到伺服器上 2:存放在磁碟中,然後資料庫中存放路徑,讀取得時候傳路徑。這個適合小項目 3:將圖片轉換成二進位文件,但是不建議這樣做,因為會給資料庫造成壓力。 4:存放在雲存儲器上,也是在資料庫上存地址,不過是雲地址,使 ...
  • 第一部分:面向對象 封裝 繼承(里氏轉換) 多態第二部分:值類型、引用類型、字元串操作第三部分:集合文件操作第四部分:正則表達式第五部分:XML操作第六部分:委托、事件第七部分:反射。 //存儲著我們當前正在運行的進程//Process[] pro = Process.GetProcesses(); ...
  • 在很多時候,我們做一些非常規化的界面的時候,往往需要創建一些用戶控制項,在其中繪製好一些基礎的界面塊,作為後續重覆使用的一個單元,用戶控制項同時也可以封裝處理一些簡單的邏輯。在開發Winform各種類型項目,我都時不時需要定製一些特殊的用戶控制項,以方便在界面模塊中反覆使用。我們一般是在自定義的用戶控制項里... ...
一周排行
  • 比如要拆分“呵呵呵90909086676喝喝999”,下麵當type=0返回的是中文字元串“呵呵呵,喝喝”,type=1返回的是數字字元串“90909086676,999”, private string GetStrings(string str,int type=0) { IList<strin ...
  • Swagger一個優秀的Api介面文檔生成工具。Swagger可以可以動態生成Api介面文檔,有效的降低前後端人員關於Api介面的溝通成本,促進項目高效開發。 1、使用NuGet安裝最新的包:Swashbuckle.AspNetCore。 2、編輯項目文件(NetCoreTemplate.Web.c ...
  • 2020 年 7 月 30 日, 由.NET基金會和微軟 將舉辦一個線上和為期一天的活動,包括 微軟 .NET 團隊的演講者以及社區的演講者。本次線上大會 專註.NET框架構建微服務,演講者分享構建和部署雲原生應用程式的最佳實踐、模式、提示和技巧。有關更多信息和隨時瞭解情況:https://focu... ...
  • #abp框架Excel導出——基於vue #1.技術棧 ##1.1 前端採用vue,官方提供 UI套件用的是iview ##1.2 後臺是abp——aspnetboilerplate 即abp v1,https://github.com/aspnetboilerplate/aspnetboilerp ...
  • 前言 本文的文字及圖片來源於網路,僅供學習、交流使用,不具有任何商業用途,版權歸原作者所有,如有問題請及時聯繫我們以作處理。 作者:碧茂大數據 PS:如有需要Python學習資料的小伙伴可以加下方的群去找免費管理員領取 input()輸入 Python提供了 input() 內置函數從標準輸入讀入一 ...
  • 從12年到20年,python以肉眼可見的趨勢超過了java,成為了當今It界人人皆知的編程語言。 python為什麼這麼火? 網路編程語言搜索指數 適合初學者 Python具有語法簡單、語句清晰的特點,這就讓初學者在學習階段可以把精力集中在編程對象和思維方法上。 大佬都在用 Google,YouT ...
  • 在社會上存在一種普遍的對培訓機構的學生一種歧視的現象,具體表現在,比如:當你去公司面試的時候,一旦你說了你是培訓機構出來的,那麼基本上你就涼了,那麼你瞞著不說,然後又通過了面試成功入職,但是以後一旦在公司被髮現有培訓經歷,可能會面臨被降薪,甚至被辭退,培訓機構出來的學生,在用人單位眼裡就是能力低下的 ...
  • from typing import List# 這道題看了大佬寫的代碼,經過自己的理解寫出來了。# 從最外圍的四周找有沒有為O的,如果有的話就進入深搜函數,然後深搜遍歷# 判斷上下左右的位置是否為Oclass Solution: def solve(self, board: List[List[s ...
  • import requests; import re; import os; # 1.請求網頁 header = { "user-agent":'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_5) AppleWebKit/537.36 (KHTML, li ...
  • import requests; import re; import os; import parsel; 1.請求網頁 header = { "user-agent":'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_5) AppleWebKit/537. ...