当前位置:Gxlcms > 数据库问题 > Linq To Sql中实现Left Join与Inner Join使用Linq语法与lambda表达式

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

时间:2021-07-01 10:21:17 帮助过:3人阅读

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()是为了一次性将数据取到本地.

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

标签:

人气教程排行