0

我想從實體我的存儲過程的情況下,我可以使用這樣的:如何獲取IQueryable的存儲過程?

var WagonQuery = db.spGetTravelBYRTravelInfo(DepartureDate, FromId, ToId); 

if (WagonId != 0) 
    WagonQuery = WagonQuery.Where(p => p.WagonID == WagonId); // HERE IS ERROR. Wagonquery Can Not Uses Like forexample List,So I Can Filter It And Use Several Where Clauses 

grdTravels.DataSource = WagonQuery; 
grdTravels.DataBind(); 

以下是錯誤:

Cannot implicitly convert type 'System.Collections.Generic.IEnumerable' to 'System.Data.Objects.ObjectResult'. An explicit conversion exists (are you missing a cast?)

回答

0

我應該將它轉換到列表中,然後(就像這):

 List<spGetTravelBYRTravelInfo_Result> lst = db.spGetTravelBYRTravelInfo(DepartureDate, FromId, ToId).ToList(); 
    var dt = lst.Select(p => p); 
    if (WagonId != 0) 
     dt = dt.Where(p => p.WagonID == WagonId); 
    if (ddlReserved.SelectedValue == "t") 
     dt = dt.Where(p => p.Presell > 0); 
0

我找不出你的存儲過程返回。在使用EF 6.1.3通過做以下我的項目,你可以從數據庫

List<SparePart> spSpares = db.Database.SqlQuery<SparePart>("spGetSparePartsFromProductId " + Convert.ToString(productId) + "," + Convert.ToString(subProduct)); 

在哪裏我的模型是

public partial class SparePart 
    { 
     public long ItemID { get; set; } 
     public string ItemCode { get; set; } 
     public string ItemName { get; set; } 
     public Nullable<decimal> ItemPrice { get; set; } 
     public bool IsActive { get; set; } 
     public string ItemDesc { get; set; } 
     public Nullable<int> ItemGroup { get; set; } 
     public string Model { get; set; } 
     public string MajorCategory { get; set; } 
     public string MinorCategory { get; set; } 
     public string UOM { get; set; } 
    } 

和產生相同的存儲過程

CREATE PROC [dbo].[spGetSparePartsFromProductId] 
(
@productId bigint, 
@subproductId bigint=0 
) 
AS 
BEGIN 
if @productId=1 
select * from SpareParts 
END 
GO 

動態篩選列表as SpareParts表

Same as Model

可能會有所幫助