热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

C#实现的Table的Merge,以及实现Table的Copy和Clone

C#实现的对两个Table进行Merge,两表必须存在至少一个公共栏位作为连接项,否则连接就失去了意义。如下是对两个table进行Merge的详细代码:privatevoidbut

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 )
            {
                name[i] = table1.Rows[i]["NAME"].ToString();
                id[i] = table1.Rows[i]["ID"].ToString();
            }
                      
            table1.Clear();//清空表中的数据

            //Clone
            var table2 = dt2.Clone();//Clone,复制表的结构、约束信息

            #endregion

        }

C#实现的Table的Merge,以及实现Table的Copy和Clone


推荐阅读
  • 本文介绍了OC学习笔记中的@property和@synthesize,包括属性的定义和合成的使用方法。通过示例代码详细讲解了@property和@synthesize的作用和用法。 ... [详细]
  • android listview OnItemClickListener失效原因
    最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ... [详细]
  • 本文介绍了C#中数据集DataSet对象的使用及相关方法详解,包括DataSet对象的概述、与数据关系对象的互联、Rows集合和Columns集合的组成,以及DataSet对象常用的方法之一——Merge方法的使用。通过本文的阅读,读者可以了解到DataSet对象在C#中的重要性和使用方法。 ... [详细]
  • 导出功能protectedvoidbtnExport(objectsender,EventArgse){用来打开下载窗口stringfileName中 ... [详细]
  • 如何自行分析定位SAP BSP错误
    The“BSPtag”Imentionedintheblogtitlemeansforexamplethetagchtmlb:configCelleratorbelowwhichi ... [详细]
  • 本文介绍了使用kotlin实现动画效果的方法,包括上下移动、放大缩小、旋转等功能。通过代码示例演示了如何使用ObjectAnimator和AnimatorSet来实现动画效果,并提供了实现抖动效果的代码。同时还介绍了如何使用translationY和translationX来实现上下和左右移动的效果。最后还提供了一个anim_small.xml文件的代码示例,可以用来实现放大缩小的效果。 ... [详细]
  • HDU 2372 El Dorado(DP)的最长上升子序列长度求解方法
    本文介绍了解决HDU 2372 El Dorado问题的一种动态规划方法,通过循环k的方式求解最长上升子序列的长度。具体实现过程包括初始化dp数组、读取数列、计算最长上升子序列长度等步骤。 ... [详细]
  • 如何使用Java获取服务器硬件信息和磁盘负载率
    本文介绍了使用Java编程语言获取服务器硬件信息和磁盘负载率的方法。首先在远程服务器上搭建一个支持服务端语言的HTTP服务,并获取服务器的磁盘信息,并将结果输出。然后在本地使用JS编写一个AJAX脚本,远程请求服务端的程序,得到结果并展示给用户。其中还介绍了如何提取硬盘序列号的方法。 ... [详细]
  • 不同优化算法的比较分析及实验验证
    本文介绍了神经网络优化中常用的优化方法,包括学习率调整和梯度估计修正,并通过实验验证了不同优化算法的效果。实验结果表明,Adam算法在综合考虑学习率调整和梯度估计修正方面表现较好。该研究对于优化神经网络的训练过程具有指导意义。 ... [详细]
  • 本文详细介绍了Java中vector的使用方法和相关知识,包括vector类的功能、构造方法和使用注意事项。通过使用vector类,可以方便地实现动态数组的功能,并且可以随意插入不同类型的对象,进行查找、插入和删除操作。这篇文章对于需要频繁进行查找、插入和删除操作的情况下,使用vector类是一个很好的选择。 ... [详细]
  • 高质量SQL书写的30条建议
    本文提供了30条关于优化SQL的建议,包括避免使用select *,使用具体字段,以及使用limit 1等。这些建议是基于实际开发经验总结出来的,旨在帮助读者优化SQL查询。 ... [详细]
  • [大整数乘法] java代码实现
    本文介绍了使用java代码实现大整数乘法的过程,同时也涉及到大整数加法和大整数减法的计算方法。通过分治算法来提高计算效率,并对算法的时间复杂度进行了研究。详细代码实现请参考文章链接。 ... [详细]
  • 本文讨论了在手机移动端如何使用HTML5和JavaScript实现视频上传并压缩视频质量,或者降低手机摄像头拍摄质量的问题。作者指出HTML5和JavaScript无法直接压缩视频,只能通过将视频传送到服务器端由后端进行压缩。对于控制相机拍摄质量,只有使用JAVA编写Android客户端才能实现压缩。此外,作者还解释了在交作业时使用zip格式压缩包导致CSS文件和图片音乐丢失的原因,并提供了解决方法。最后,作者还介绍了一个用于处理图片的类,可以实现图片剪裁处理和生成缩略图的功能。 ... [详细]
  • Day2列表、字典、集合操作详解
    本文详细介绍了列表、字典、集合的操作方法,包括定义列表、访问列表元素、字符串操作、字典操作、集合操作、文件操作、字符编码与转码等内容。内容详实,适合初学者参考。 ... [详细]
  • 本文详细介绍了使用C#实现Word模版打印的方案。包括添加COM引用、新建Word操作类、开启Word进程、加载模版文件等步骤。通过该方案可以实现C#对Word文档的打印功能。 ... [详细]
author-avatar
MIKO_CHEUNG2011
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有