C#中连接两个DataTable,相当于Sql的InnerJoin

作者:凯旋网络来源:凯旋网络

    在下面的例子中实现了3个Join方法,其目的是把两个DataTable连接起来,相当于Sql的Inner Join方法,返回DataTable的所有列。
如果两个DataTable中的DataColumn有重复的话,把第二个设置为ColumnName+"_Second",下面是代码,希望对大家有所帮助。
using System;
using System.Data;

中国站.长.站

namespace WindowsApplication1
{
    public class SQLOps
    {
        public SQLOps()
        {           
        }
        public static DataTable Join (DataTable First, DataTable Second, DataColumn[] FJC, DataColumn[] SJC)
        {
            //创建一个新的DataTable
            DataTable table = new DataTable("Join");
            // Use a DataSet to leverage DataRelation
            using(DataSet ds = new DataSet()) 中国站长_站,为中文网站提供动力
            {
                //把DataTable Copy到DataSet中

Www_Chinaz_com

                ds.Tables.AddRange(new DataTable[]{First.Copy(),Second.Copy()});

Www_Chinaz_com

                DataColumn[] parentcolumns = new DataColumn[FJC.Length]; Www_Chinaz_com

                for(int i = 0; i < parentcolumns.Length; i++)
                {
                    parentcolumns[i] = ds.Tables[0].Columns[FJC[i].ColumnName];
                }
                DataColumn[] childcolumns = new DataColumn[SJC.Length];
                for(int i = 0; i < childcolumns.Length; i++)
                {
                    childcolumns[i] = ds.Tables[1].Columns[SJC[i].ColumnName];

中.国站长站

                }
[中国站长站]

          &n

  • 广告推荐