第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問(wèn)題,去搜搜看,總會(huì)有你想問(wèn)的

沒(méi)有DbSet的原始SQL查詢(xún)-實(shí)體框架核心

沒(méi)有DbSet的原始SQL查詢(xún)-實(shí)體框架核心

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

3 回答

?
RISEBY

TA貢獻(xiàn)1856條經(jīng)驗(yàn) 獲得超5個(gè)贊

如果您使用的是自2018年5月7日起可用的EF Core 2.1 Release Candidate 1,則可以利用建議的新功能(查詢(xún)類(lèi)型)。


什么是查詢(xún)類(lèi)型?


除實(shí)體類(lèi)型外,EF Core模型還可包含查詢(xún)類(lèi)型,該查詢(xún)類(lèi)型可用于對(duì)未映射到實(shí)體類(lèi)型的數(shù)據(jù)執(zhí)行數(shù)據(jù)庫(kù)查詢(xún)。


什么時(shí)候使用查詢(xún)類(lèi)型?


用作臨時(shí)FromSql()查詢(xún)的返回類(lèi)型。


映射到數(shù)據(jù)庫(kù)視圖。


映射到未定義主鍵的表。


映射到模型中定義的查詢(xún)。


因此,您不再需要進(jìn)行建議作為問(wèn)題答案的所有技巧或變通方法。只需按照以下步驟操作:


首先,您定義一個(gè)新的type屬性,DbQuery<T>其中Ttype是將攜帶SQL查詢(xún)的列值的類(lèi)的類(lèi)型。因此,您DbContext將擁有:


public DbQuery<SomeModel> SomeModels { get; set; }

其次,使用FromSql與您類(lèi)似的方法DbSet<T>:


var result = context.SomeModels.FromSql("SQL_SCRIPT").ToList();

var result = await context.SomeModels.FromSql("SQL_SCRIPT").ToListAsync();

還要注意,DBContext是局部類(lèi),因此您可以創(chuàng)建一個(gè)或多個(gè)單獨(dú)的文件來(lái)組織“ raw SQL DbQuery”定義,以使其最適合您。


查看完整回答
反對(duì) 回復(fù) 2019-10-18
?
縹緲止盈

TA貢獻(xiàn)2041條經(jīng)驗(yàn) 獲得超4個(gè)贊

在EF Core中,您不再可以執(zhí)行“免費(fèi)”原始sql。您需要定義POCO類(lèi)和DbSet該類(lèi)的。在您的情況下,您需要定義Rank:


var ranks = DbContext.Ranks

   .FromSql("SQL_SCRIPT OR STORED_PROCEDURE @p0,@p1,...etc", parameters)

   .AsNoTracking().ToList();

由于肯定是只讀的,因此包含該.AsNoTracking()調(diào)用將很有用。


查看完整回答
反對(duì) 回復(fù) 2019-10-18
  • 3 回答
  • 0 關(guān)注
  • 741 瀏覽

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢(xún)優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)