亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

沒有DbSet的原始SQL查詢-實體框架核心

沒有DbSet的原始SQL查詢-實體框架核心

C#
慕的地6264312 2019-10-18 11:12:35
刪除Entity Framework Core后,dbData.Database.SqlQuery<SomeModel>我找不到為我的全文搜索查詢構建原始SQL查詢的解決方案,該查詢將返回表數據以及排名。我看到的在Entity Framework Core中構建原始SQL查詢的唯一方法是通過dbData.Product.FromSql("SQL SCRIPT");,它沒有用,因為我沒有DbSet可以映射在查詢中返回的排名。有任何想法嗎???
查看完整描述

3 回答

?
RISEBY

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”定義,以使其最適合您。


查看完整回答
反對 回復 2019-10-18
?
縹緲止盈

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()調用將很有用。


查看完整回答
反對 回復 2019-10-18
  • 3 回答
  • 0 關注
  • 746 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號