Skip to main content

Compare Data Tables Using LINQ Union, Except and Intersect

In this post i am going to explain about how to compare two datatables using  Union, Except and Intersect LinQ operators.
Compare Data Tables Using LINQ Union, Except and Intersect
Process:
1. Create two datatable for holding the student records. One for holding students who enrolled for yoga class and another one is  students who enrolled for karate class. Below is the code.

//Table contains students data who enrolled
//to yoga class
DataTable dtYoga = new DataTable("YogaClass");
dtYoga.Columns.Add("StudentId", typeof(int));
dtYoga.Columns.Add("StudentName", typeof(string));
dtYoga.Columns.Add("Age", typeof(int));
dtYoga.Columns.Add("Place", typeof(string));

//Adding sample records
dtYoga.Rows.Add(1, "Kanna", 28, "Chennai");
dtYoga.Rows.Add(2, "Dasan", 29, "Avadi");
dtYoga.Rows.Add(3, "Kavi", 27, "Ambur");
dtYoga.Rows.Add(4, "Arasan", 30, "Delhi");
dtYoga.Rows.Add(5, "Xavier", 25, "Bangalore");

//Table contains students data who enrolled
//to karate class
DataTable dtKarate = new DataTable("KarateClass");
dtKarate.Columns.Add("StudentId", typeof(int));
dtKarate.Columns.Add("StudentName", typeof(string));
dtKarate.Columns.Add("Age", typeof(int));
dtKarate.Columns.Add("Place", typeof(string));

//Adding sample records
dtKarate.Rows.Add(6, "Arvind", 24, "Ambattur");
dtKarate.Rows.Add(1, "Kanna", 28, "Chennai");
dtKarate.Rows.Add(3, "Kavi", 27, "Ambur");
dtKarate.Rows.Add(7, "John", 24, "Velachery");
dtKarate.Rows.Add(4, "Paul",22, "Adambakkam");
dtKarate.Rows.Add(4, "Arasan", 30, "Delhi");

2. Now i am printing all the students using the Union operator.

// Printing the list of all students using Union
Console.WriteLine("\t-------------------------------");
Console.WriteLine("\tPrinting the list of all students using Union");
Console.WriteLine("\t-------------------------------");

DataTable dtBoth = dtYoga.AsEnumerable().Union(dtKarate.AsEnumerable(), DataRowComparer.Default).CopyToDataTable();
foreach (DataRow dr in dtBoth.Rows)
{
    Console.WriteLine(string.Format("\tStudentId: {0}, StudentName: {1}",
        dr[0].ToString(), dr[1].ToString()));
}

The output will be

Linq Union Example

3. Now here i am printing the students who enrolled only for yoga and karate class using Except operator.

// Finding out students who enrolled only to Yoga Classes using Except
DataTable dtOnlyYoga = dtYoga.AsEnumerable().Except(dtKarate.AsEnumerable(), DataRowComparer.Default).CopyToDataTable();

Console.WriteLine("\t");
Console.WriteLine("\tEnrolled Students - Only for Yoga Classes using Except");
Console.WriteLine("\t-------------------------------");
foreach (DataRow dr in dtOnlyYoga.Rows)
{
    Console.WriteLine(string.Format("\tStudentId: {0}, StudentName: {1}",
        dr[0].ToString(), dr[1].ToString()));
}
// Finding out students who enrolled only to Yoga Classes using Except
Console.WriteLine("\t");
Console.WriteLine("\tEnrolled Students - Only for Karate Classes using Except");
Console.WriteLine("\t-------------------------------");
DataTable dtOnlyKarate = dtKarate.AsEnumerable().Except(dtYoga.AsEnumerable(), DataRowComparer.Default).CopyToDataTable();
foreach (DataRow dr in dtOnlyKarate.Rows)
{
    Console.WriteLine(string.Format("\tStudentId: {0}, StudentName: {1}",
        dr[0].ToString(), dr[1].ToString()));
}

The output will look like

Linq Except Example

4. Now here i am getting the students who enrolled for both the yoga and karate class using Intersect operator.

// Finding out students who enrolled to Both Yoga Classes using Intersect
Console.WriteLine("\t");
Console.WriteLine("\tEnrolled Students - For Both Yoga & Karate Classes using Intersect");
Console.WriteLine("\t-------------------------------");

DataTable dtBothClasses = dtYoga.AsEnumerable().Intersect(dtKarate.AsEnumerable(), DataRowComparer.Default).CopyToDataTable();
foreach (DataRow dr in dtBothClasses.Rows)
{
    Console.WriteLine(string.Format("\tStudentId: {0}, StudentName: {1}",
        dr[0].ToString(), dr[1].ToString()));
}

The output will look like

Linq Intersect Example

You can download the entire sourcecode below.
Source Code of Compare Data Tables Using LINQ Union, Except and Intersect
If you like this article please share it with your friends. Do comment your thoughts and doubts if any.

Comments

Popular posts from this blog

Code To Convert rupees(numbers) into words using C#.Net

Introduction: In my previous article I have explained about how to validate emailid using javascript . In this article I am going to explain about code used to convert rupees(numbers) into words using C#.Net . Explanation: For explanation purpose I have a page. It has a textbox to input the numbers. And when you click on the convert to words button then it will convert the input numbers into words and shows it in the below label. Below is the C# code used to do this functionality. public static string NumbersToWords( int inputNumber) {     int inputNo = inputNumber;     if (inputNo == 0)         return "Zero" ;     int [] numbers = new int [4];     int first = 0;     int u, h, t;     System.Text. StringBuilder sb = new System.Text. StringBuilder ();     if (inputNo < 0)     { ...

Puzzles for kids - 12 Days Of Christmas

According to the traditional song, on the first day of Christmas (25th December), my true love sent to me: . A partridge in a pair tree On the second day of Christmas (26th December), my true love sent to me THREE presents: . Two turtle doves . A partridge in a pear tree On the third day of Christmas (27th December and so on) my true love sent to me SIX presents: . Three French hens . Two turtle doves . A partridge in a pear tree This carries on until the the twelfth day of Christmas, when my true love sends me: Twelve drummers drumming Eleven pipers piping Ten lords a-leaping Nine ladies dancing Eight maids a-milking Seven swans a-swimming Six geese a-laying Five gold rings Four calling birds Three French hens Two turtle doves A partridge in a pear tree After the twelve days of Christmas are over, how many presents has my true love sent me altogether? Our Solution: 1 + 3 + 6 + 10 + 15 + 21 + 28 + 36 + 45 + 55 + 66 + 78 = 364 presents Which is really interesting when you think ...

Asp.Net DataTable Manipulation - Add, Update,Delete & Sort DataTable in C#.Net & VB.Net

In the asp.net developer's life it is very common to come across the datatable manipulation. So here i have decided to explain the datatable manipulation like adding records to datatable, editing and updating datatable records,deleting records from datatable based on the condition and finally sorting datatable based on columns.