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

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

允許數(shù)據(jù)庫查詢但獨立于所使用的數(shù)據(jù)庫提供程序的設(shè)計模型

允許數(shù)據(jù)庫查詢但獨立于所使用的數(shù)據(jù)庫提供程序的設(shè)計模型

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

1 回答

?
郎朗坤

TA貢獻1921條經(jīng)驗 獲得超9個贊

現(xiàn)在唯一有效的方法是永遠保留 dbContext,并為給定存儲庫實現(xiàn)中的所有查詢共享它。


不可以。DbContext 的范圍應(yīng)限于工作單元,這可能涉及多個存儲庫實例。


一個簡單的實現(xiàn)是將 DbContext 注入每個存儲庫類型的構(gòu)造函數(shù)中。例如


using (var db = new MyDatabase())

{

   var things = new ThingRepository(db);

   var anotherThings = new AnotherThingRepository(db);


   . . .


   db.SaveChanges();

}


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

添加回答

舉報

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

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

公眾號

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