簡體   English   中英

休眠一個isession相同的idbconnection

[英]nhibernate one isession same idbconnection

我有一些代碼在同一個ISession上執行2次session.Get(id)。 我可以看到ISession創建了2個idbconnections。 我猜這是因為某種配置。 我希望它在相同的idbconnection上進行提取。 怎么樣?

如果兩個Get操作都在同一個事務中,則它們將共享相同的IDbConnection 否則,您最終將獲得隱式事務,NHibernate將為每個查詢打開和關閉一個IDbConnection 通常,您應該嘗試執行以下操作:

using (var tx = session.BeginTransaction())
{
    var customer = session.Get<Customer>(123);
    var order = session.Get<Order>(456);

    // do stuff

    tx.Commit();
}

不鼓勵使用隱式事務

當我們不定義自己的事務時,它會退回到隱式事務模式,在該模式下,數據庫的每個語句都在其自己的事務中運行,從而導致巨大的性能成本(建立和拆除事務的數據庫時間),並降低了一致性。

即使我們僅讀取數據,也應該使用事務,因為使用事務可確保我們從數據庫中獲得一致的結果。 NHibernate假定所有對數據庫的訪問都是在事務下完成的,並且強烈建議不要使用沒有事務的會話。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM