我有以下界面: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 );
}
那不是更容易嗎?
- 1 回答
- 0 關(guān)注
- 134 瀏覽
添加回答
舉報(bào)
0/150
提交
取消