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

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

在 EF 中動態(tài)設(shè)置數(shù)據(jù)源

在 EF 中動態(tài)設(shè)置數(shù)據(jù)源

C#
哈士奇WWW 2021-11-14 14:48:58
我正在使用 EF6,并且有 2 個不同版本的數(shù)據(jù)庫 (MsSQL)。1 個版本有一個表 Person 而另一個沒有。我正在覆蓋OnModelCreating并且我使用modelBuilder.Ignore<Person>(); This 來調(diào)用其他表的數(shù)據(jù)庫。我想要完成的是,當(dāng)我通過 EF 調(diào)用實體時,它返回類 Person 的新實例,而不是嘗試連接到數(shù)據(jù)庫并獲取其數(shù)據(jù)。例如:using(MyEntity ent = new MyEntity("connectionString"){  var myPerson = ent.Person.FirstOrDefault(); ==> Depending on version, return the DBData or new Person()}
查看完整描述

1 回答

?
繁星點點滴滴

TA貢獻(xiàn)1803條經(jīng)驗 獲得超3個贊

我假設(shè)您可以向上下文的構(gòu)造函數(shù)添加一個布爾參數(shù):


public MyEntity(string connectionString, bool includePerson)

{

    _includePersion = includePerson;

}

現(xiàn)在上下文可以有一個屬性Person,或者最好是復(fù)數(shù)形式People:


public IQueryable<Person> People

{

    get => _includePerson 

        ? Set<Person>()

        : (new[] { new Person() }).AsQueryable();

}

從技術(shù)上講,您現(xiàn)在應(yīng)該擺脫困境,因為沒有 to/from 導(dǎo)航屬性Person。但是,我擔(dān)心這種構(gòu)造可能會在下游產(chǎn)生比乍一看預(yù)期更多的后果。我會盡一切努力避免它。在Person沒有它的情況下向數(shù)據(jù)庫添加一個空表會好得多。這甚至可以由應(yīng)用程序本身完成,前提是登錄的數(shù)據(jù)庫用戶具有所需的 DDL 權(quán)限。


查看完整回答
反對 回復(fù) 2021-11-14
  • 1 回答
  • 0 關(guān)注
  • 148 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

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

公眾號

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