首页 > 代码库 > linq中如何实现多个条件的联合查询

linq中如何实现多个条件的联合查询

  目前接触处理数据这一块比较多,在处理内存中的数据源的时候我一般使用的是linq,linq使用起来像sql语句一样,用法简单,功能强大。

  最近需要实现一个从两个不同的文件读取不同的数据,然后根据这两个数据的一些字段经行联合,然后把他们的结果放到一个数据源里面里啊,一般的联合查询两个数据源,都是通过一个数据源的字段和另一个数据源的字段经行匹配就可以了,如果是这样的话在linq实现和在sql里面实现其实差不多,下面是单个条件的联合查询的代码如下所示

  

 var result1 = from l1 in list1
                         join l2 in list2
                         on l1.Id equals l2.Id
                         select new
                         {
                             l1Nmae = l1.Name,
                             l2Nmae = l2.Name
                         };

只是linq中使用的是equals而不是sql中的“=”; 

但是这只是一般都在的需求,如今我就要通过这两个数据的两个字段分别经行匹配才能得到我想要的数据结果,那该如何呢?

  有两种方法

  一、可以利用这次查询的结果与其中的一个数据源经过多次联合查询。代码省······

  二、linq的联合查询本身就要支持多条件的联合查询,代码如下所示

    

   var result = from l1 in list1
                         join l2 in list2
                         on new { l1.Id, l1.Age } equals new { l2.Id, l2.Age }
                         select new
                         {
                             l1Nmae=l1.Name ,
                             l2Nmae=l2.Name 
                         };

  通过new {}equals new {}来经行多条件的联合的查询。但是必须注意的是,equals左边的new中的字段个数和类型,和右边的必须要匹配,且是equalss左边第一个字段匹配右边的第一个字段,以此类推。

  这样就实现了多条件的联合查询。