LINQ的左连接、右连接、内连接

来源:互联网 发布:c语言写的小软件代码 编辑:程序博客网 时间:2024/06/05 18:49
[csharp] view plain copy
  1. 1、左连接:  
  2. var LeftJoin = from emp in ListOfEmployees  
  3. join dept in ListOfDepartment  
  4. on emp.DeptID equals dept.ID into JoinedEmpDept  
  5. from dept in JoinedEmpDept.DefaultIfEmpty()  
  6. select new                          
  7. {  
  8. EmployeeName = emp.Name,  
  9. DepartmentName = dept != null ? dept.Name : null                          
  10. };  
  11.    
  12. 2、右连接:  
  13. var RightJoin = from dept in ListOfDepartment  
  14. join employee in ListOfEmployees  
  15. on dept.ID equals employee.DeptID into joinDeptEmp  
  16. from employee in joinDeptEmp.DefaultIfEmpty()  
  17. select new                            
  18. {  
  19. EmployeeName = employee != null ? employee.Name : null,  
  20. DepartmentName = dept.Name  
  21. };  
  22.    
  23. 3、内连接:  
  24.  var query = from t in entitiy.TB_GCGL_ADA_USER  
  25.                  join p in entitiy.TB_GCGL_ZY_ZYK  
  26.                  on t.ETPRS_CODE equals p.ETPRS_CODE  
  27.                  select new TB_USER_ZYK  
  28.                  {  
  29.                     USER_ID = t.USER_ID,  
  30.                     USER_NAME = t.USER_NAME,  
  31.                     USER_PASSWORD = t.USER_PASSWORD,  
  32.                  };  
原创粉丝点击