2012-03-20 54 views
14

我有以下表格:如何在LINQ-to-SQL中編寫這個交叉應用查詢?

create table TableA (
    Id int primary key identity, 
    Key int not null 
) 

create table TableB (
    Id int primary key identity, 
    TableA_Id int not null foreign key references TableA(Id), 
    Value varchar(80) not null 
) 

我想編寫的LINQ到SQL使用lambda符號下面的查詢:

select TableA.Key, b.Value 
from TableA 
cross apply (
    select top 10 TableB.Value 
    from TableB 
    where TableA.Id = TableB.TableA_Id 
    order by TableB.Value 
) b 
where TableA.Key between 0 and 999 

我會怎麼做呢?

回答

19

這應該做的伎倆

var query = from a in context.TableA 
      from b in context.TableB 
          .Where(x => x.TableA_Id == a.Id) 
          .OrderBy(x => x.Value) 
          .Take(10) 
      where a.Key >= 0 && a.Key <= 999 
      select new 
      { 
       a.Key, 
       b.Value, 
      }; 
1

//獲取每個用戶

var query = ActivityRepository.Where(p => p.iAction > -1 && 

    userIds.Contains(p.iSellerId)).GroupBy(c => c.iSellerId).Select(c => c.OrderByDescending(cc => cc.dBeginTime).First()).Select(a => new ActivityInfo 

     { 
      ActivityId = a.iActivityId, 
      StartTime = a.dBeginTime, 
      SellerId = a.iSellerId, 
      EndTime = a.dEndTime, 
      ActivityName = a.sName, 
     }); 

該代碼會產生外部應用最新的語法時才活動信息。