zoukankan      html  css  js  c++  java
  • Linq To Sql中实现Left Join与Inner Join使用Linq语法与lambda表达式

    当前有两个表,sgroup与sgroupuser,两者通过gKey关联,而sgroup表记录的是组,而sgroupuser记录是组中的用户,因此在sgroupuser中不一定有数据。需要使用Left Join获取数据:

    Linq语法如下:

    var sg = (from g in dc.sgroup
                         join gu in dc.sgroupuser on g.gKey equals gu.gKey into l
                         from lgu in l.DefaultIfEmpty()
                          select new { g, lgu }).ToList();

    Lambda表达式如下:

    var sg = dc.sgroup.GroupJoin(dc.sgroupuser, g => g.gKey, gu => gu.gKey, (g, gu) => new { g, gu }).Select(o=>o).ToList() ;

    注意:

        Linq 与Lambda表达式取出的结果有所不同.Linq取出的结果的记录数与Sql中的Left Join的结果相同,而Lambda表达式取出的记录数是sgroup表中的记录数,sgroupuser对应的记录是以对象集合存在于结果中

    附:

    下面是Inner Join:

    Linq语法如下:

    var sg = (from g in dc.sgroup
                        join gu in dc.sgroupuser on g.gKey equals gu.gKey                  
                        select new { g, gu }).ToList();

    Lambda表达式如下:

    var sg = dc.sgroup.Join(dc.sgroupuser, g => g.gKey, gu => gu.gKey, (g, gu) => new { g, gu }).Select(o=>o).ToList() ;

    注意:

       上面最后都用到了ToList()方法 , 用ToList()是为了一次性将数据取到本地.

    转载:http://blog.sina.com.cn/s/blog_95cfa64601019vs1.html

    Linq To Sql中实现Left Join与Inner Join使用Linq语法与lambda表达式

  • 相关阅读:
    js返回上个页面再刷新
    xm-select 获取选选择的值
    接口可以跨域访问
    gitlab 版本查看
    gitlab 在linux安装环境下存储地址
    iosUILable基本使用及其所有方法
    iOS富文本字符串AttributedString具体用法
    SQL Server 开发指南
    SQL Server 数据库安全
    SQL Server 触发器
  • 原文地址:https://www.cnblogs.com/spring-sd/p/4923194.html
Copyright © 2011-2022 走看看