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

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

使用泛型和接口轉(zhuǎn)換問題的 Linq 查詢

使用泛型和接口轉(zhuǎn)換問題的 Linq 查詢

C#
小唯快跑啊 2023-09-16 16:57:53
我有以下界面:public interface IInactive{    bool inactive { get; set; }}以及實(shí)現(xiàn)該接口的幾個(gè)對(duì)象(實(shí)體框架實(shí)體),例如:public class Order : IInactive{    [Key]    [Required]    public Guid orderId { get; set; }    ...    public bool inactive { get; set; }} 我正在嘗試實(shí)現(xiàn)一個(gè)通用方法,該方法可用于僅返回“活動(dòng)”記錄(即非活動(dòng)== false)。它將被稱為如下:var query = GetAllActive<Order>();我的這個(gè)通用方法的代碼如下所示:public IQueryable<T> GetAllActive<T>() where T : class{    DbSet<T> dbSet = this._db.Set<T>();    IQueryable<IInactive> query2 = dbSet as IQueryable<IInactive>;    query2 = query2.Where(w => !w.inactive);    return (DbSet <T>)query2;    // System.InvalidCastException: 'Unable to cast object of type 'System.Data.Entity.Infrastructure.DbQuery`1[Portal.Domain.Entities.Interfaces.IInactive]' to type 'System.Data.Entity.DbSet`1[Portal.Domain.Entities.Order]'.'}
查看完整描述

1 回答

?
有只小跳蛙

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

由于您的代碼僅適用于繼承自 的記錄IActive,因此對(duì)其進(jìn)行約束。當(dāng)您這樣做時(shí),屬于該接口的屬性和方法在 的實(shí)例中變得可用T。


public IQueryable<T> GetAllActive<T>() where T : IActive  //Here is the magic

{

    return this._db.Set<T>()

        .Where( w => !w.inactive );

}

那不是更容易嗎?


查看完整回答
反對(duì) 回復(fù) 2023-09-16
  • 1 回答
  • 0 關(guān)注
  • 134 瀏覽

添加回答

舉報(bào)

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

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

公眾號(hào)

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