SQL查询到IQueryable

时间:2014-07-18 03:03:48

标签: c# sql sql-server iqueryable

我想问一下如何将此SQL查询转换为IQueryable:

SQL查询:

  SELECT 
    [s].[Id] AS [Id], 
    [s].[PartId] AS [PartId], 
    [s].[Quantity] AS [Quantity], 
    [s].[OfficeId] AS [OfficeId], 
    [s].[StockLocationId] AS [StockLocationId], 
    [s].[StockSubLocationId] AS [StockSubLocationId],
    [p].[Description] AS [PartDescription],
    [p].[StdSellPrice] AS [PartSellPrice]
    FROM [dbo].[Stock] AS [s]
    INNER JOIN [dbo].[Part] AS p ON [p].Id = [s].PartId
    WHERE ([s].[StockLocationId] >= 1) AND ([s].[StockSubLocationId] <= 2)

到目前为止,我已经达到了这个IQueryable:

var getStockDetails = tempCtx.Stocks.Where(s => s.StockLocationId >= loc && s.StockSubLocationId <= subLoc);

2 个答案:

答案 0 :(得分:0)

var getStockDetails = 
    from s in tempCtx.Stocks
    join p in tempCtx.Part on s.PartId equals p.Id
    where s.StockLocationId >= 1 and s.StockSubLocationId <= 2
    select new { Id = s.Id, PartId = s.PartId, Quantity = s.Quantity };

只需在要返回的其他列的选择部分上添加。

答案 1 :(得分:0)

试试这个:

var q = tempCtx.Stocks.
            Join(tempCtx.Parts, x => x.PartID, y => y.ID, (x,y) => new{x=x,y=y}).
            Where(xy=>xy.x.StockLocationID >= 1 && xy.x.StockSubLocationID <= 2).
            Select(xy => new {
                              xy.x.ID, 
                              xy.x.PartID, 
                              xy.x.Quantity, 
                              xy.x.OfficeID, 
                              xy.x.StockLocationID, 
                              xy.x.StockSubLocationID, 
                              xy.y.Description, 
                              xy.y.StdSellPrice});