我們目前使用實體框架來訪問我們的數據庫。我們有一個大類,有數千行長,充滿了查詢數據庫的方法。 void saveFirstThing() { using (var dbContext = new DatabaseContext()) { ... } } AnotherThing returnAnotherThing() { using (var dbContext = new DatabaseContext()) { ... } } ...但是,如果我們想更改數據庫提供程序(或使用假值測試我們的應用程序),那么這樣做會非常煩人。所以我創建了:接口,它提供帶有- , , , ...IRepository<T>的操作TGet(int id)Add(T entity)GetAll()接口的實現,通過調用 EF 并返回 IQueryable 來實現方法。 public class AnotherThingRepository : IRepository<AnotherThing> { ... public IQueryable GetAll() { ... } ... } public class Something { AnotherThing returnAnotherThing() { return anotherThingRepository.GetAll().Where(...).Single(); } }但是,我有一個問題。我們有需要連接多個表的方法。所以我不能使用using(dbContext)的內部實現,因為它會在我們完成查詢結果(類型為 )之前IRepository刪除。我無法返回or ,因為它不會加載所有連接的字段(并且可能有很多)。如果我想做一些混亂的反射,它會很慢并且充滿了我需要解決的循環引用。dbContextIQueryableIEnumerableList最好的解決方案是什么?現在唯一有效的方法是dbContext永遠保留,并為給定存儲庫實現中的所有查詢共享它。然而,當我需要從數據庫更新某些內容時,它會停止工作,因為dbContext緩存所有內容,并且 dbContext 不應該以我現在使用它的方式使用。
1 回答

郎朗坤
TA貢獻1921條經驗 獲得超9個贊
現在唯一有效的方法是永遠保留 dbContext,并為給定存儲庫實現中的所有查詢共享它。
不可以。DbContext 的范圍應限于工作單元,這可能涉及多個存儲庫實例。
一個簡單的實現是將 DbContext 注入每個存儲庫類型的構造函數中。例如
using (var db = new MyDatabase())
{
var things = new ThingRepository(db);
var anotherThings = new AnotherThingRepository(db);
. . .
db.SaveChanges();
}
- 1 回答
- 0 關注
- 117 瀏覽
添加回答
舉報
0/150
提交
取消