Join three object list : Join « LINQ « C# / CSharp Tutorial

Home
C# / CSharp Tutorial
1.Language Basics
2.Data Type
3.Operator
4.Statement
5.String
6.struct
7.Class
8.Operator Overload
9.delegate
10.Attribute
11.Data Structure
12.Assembly
13.Date Time
14.Development
15.File Directory Stream
16.Preprocessing Directives
17.Regular Expression
18.Generic
19.Reflection
20.Thread
21.I18N Internationalization
22.LINQ
23.GUI Windows Forms
24.Windows Presentation Foundation
25.Windows Communication Foundation
26.Workflow
27.2D
28.Design Patterns
29.Windows
30.XML
31.XML LINQ
32.ADO.Net
33.Network
34.Directory Services
35.Security
36.unsafe
C# / C Sharp
C# / C Sharp by API
C# / CSharp Open Source
C# / CSharp Tutorial » LINQ » Join 
22.8.3.Join three object list
using System;
using System.Collections;
using System.Collections.Generic;
using System.Text;
using System.Linq;
using System.Reflection;

class Salary {
    int _id;
    int _year;
    double _salary;

    public int ID {
        get return _id; }
        set _id = value; }
    }

    public int Year {
        get return _year; }
        set _year = value; }
    }

    public double SalaryPaid {
        get return _salary; }
        set _salary = value; }
    }
}
class Employee {
    int _id;
    int _idRole;
    string _lastName;
    string _firstName;

    public int ID {
        get return _id; }
        set _id = value; }
    }

    public int IDRole {
        get return _idRole; }
        set _idRole = value; }
    }

    public string LastName {
        get return _lastName; }
        set _lastName = value; }
    }

    public string FirstName {
        get return _firstName; }
        set _firstName = value; }
    }
}
class Role {
    int _id;
    string role;

    public int ID {
        get return _id; }
        set _id = value; }
    }

    public string Role {
        get return role; }
        set role = value; }
    }
}

public class MainClass {
    public static void Main() {
        List<Employee> people = new List<Employee> {
               new Employee ID = 1, IDRole = 1, LastName = "A", FirstName = "B"},
               new Employee ID = 2, IDRole = 2, LastName = "G", FirstName = "T"},
               new Employee ID = 3, IDRole = 2, LastName = "G", FirstName = "M"},
               new Employee ID = 4, IDRole = 3, LastName = "C", FirstName = "G"}
            };
        List<Role> roles = new List<Role> {
               new Role ID = 1, Role = "Manager" },
               new Role ID = 2, Role = "Developer" }
            };
        List<Salary> salaries = new List<Salary> {
               new Salary ID = 1, Year = 2004, SalaryPaid = 10.00 },
               new Salary ID = 1, Year = 2005, SalaryPaid = 15.00 },
               new Salary ID = 1, Year = 2005, SalaryPaid = 15.00 }
            };
        var query = from p in people
                    join s in salaries on p.ID equals s.ID
                    select new p.FirstName, p.LastName, s.SalaryPaid };

        var querySum = from q in query
                       group q by q.LastName into gp
                       select new LastName = gp.Key, TotalSalary = gp.Sum(q => q.SalaryPaid) };
    }
}
22.8.Join
22.8.1.Join two object lists
22.8.2.Use join key word
22.8.3.Join three object list
22.8.4.Use Join on
22.8.5.Join Operator
22.8.6.Cartesian Join demo
22.8.7.Use == in join
22.8.8.Simple Join
22.8.9.OrderBy joined value
22.8.10.Join on substring
www.java2java.com | Contact Us
Copyright 2009 - 12 Demo Source and Support. All rights reserved.
All other trademarks are property of their respective owners.