3 回答

TA貢獻1856條經驗 獲得超5個贊
如果您使用的是自2018年5月7日起可用的EF Core 2.1 Release Candidate 1,則可以利用建議的新功能(查詢類型)。
什么是查詢類型?
除實體類型外,EF Core模型還可包含查詢類型,該查詢類型可用于對未映射到實體類型的數據執行數據庫查詢。
什么時候使用查詢類型?
用作臨時FromSql()查詢的返回類型。
映射到數據庫視圖。
映射到未定義主鍵的表。
映射到模型中定義的查詢。
因此,您不再需要進行建議作為問題答案的所有技巧或變通方法。只需按照以下步驟操作:
首先,您定義一個新的type屬性,DbQuery<T>其中Ttype是將攜帶SQL查詢的列值的類的類型。因此,您DbContext將擁有:
public DbQuery<SomeModel> SomeModels { get; set; }
其次,使用FromSql與您類似的方法DbSet<T>:
var result = context.SomeModels.FromSql("SQL_SCRIPT").ToList();
var result = await context.SomeModels.FromSql("SQL_SCRIPT").ToListAsync();
還要注意,DBContext是局部類,因此您可以創建一個或多個單獨的文件來組織“ raw SQL DbQuery”定義,以使其最適合您。

TA貢獻2041條經驗 獲得超4個贊
在EF Core中,您不再可以執行“免費”原始sql。您需要定義POCO類和DbSet該類的。在您的情況下,您需要定義Rank:
var ranks = DbContext.Ranks
.FromSql("SQL_SCRIPT OR STORED_PROCEDURE @p0,@p1,...etc", parameters)
.AsNoTracking().ToList();
由于肯定是只讀的,因此包含該.AsNoTracking()調用將很有用。
- 3 回答
- 0 關注
- 746 瀏覽
添加回答
舉報