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

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