C# 數據操做系列 - 11 NHibernate 配置和結構介紹

0. 前言

今天是NHibernate的第二篇內容,經過上一篇的內容,咱們初步瞭解了NHibernate的建立和使用。這一篇,我繼續探索NHibernate背後的祕密。嗯,就是這樣。sql

1. NHibernate結構

先給小夥伴們放個圖:數據庫

圖片

這是NHibernate的總體結構圖。NHibernate經過ADO.NET 創建訪問數據庫的鏈接,而後封裝了一個Transaction(事務)工廠和一個Session工廠。每次操做的時候,經過兩個工廠獲取對應的Session/Transaction示例操做數據對象。緩存

ISessionFactory - NHibernate.ISessionFactory:安全

一個基於單數據庫的已編譯的映射緩存,它是持久不變的且線程安全(額,這句話是從它的文檔翻譯過來的)。是一個提供ISession的工廠類,同時也是一個 IConnectionProvider的客戶端。能夠設置一個在事務之間的進程級或集羣級的二級緩存。ide

ISession - NHibernate.ISession:fetch

一個單線程、短生命週期的對象,表示從應用程序和數據持久化之間一個鏈接。一個ADO.NET鏈接的封裝,用來提供ITransaction的工廠。提供了一個經過主鍵檢索對象和導航連接查詢對象時的一級緩存。也就是EF Core中的導航屬性。spa

Persistent Objects and Collections(持久化對象和集合):hibernate

一些單線程、短生命週期對象其中包含持久化狀態和業務方法。它們可能只是一些普通的POCO,僅僅是與ISession中關聯起來了。只要ISession關閉了,這些對象就能夠被分離出來而後能夠在應用層的任意地方使用。線程

Transient Objects and Collections(臨時對象和集合):翻譯

表示臨時的未被ISession託管的持久化對象,它們被應用層臨時建立但直到ISession關閉都不會被持久化。

ITransaction - NHibernate.ITransaction:

這個是可選的。表示一個單線程、短生命週期的對象,被應用程序用來限制一個原子的工做單元,基於ADO.NET 的Transaction的抽象。一個ISession可能會開啓多個事務,Transaction scopes may be used instead(原話是這個,大意是能夠改用事務做用域)。

IConnectionProvider - NHibernate.Connection.IConnectionProvider:

也是可選的,是一個用來建立ADO.NET Connection和Command的工廠。基於DbConnection和DbCommand實現,並不是直接暴露給應用程序,可是能夠由開發者對其進行擴展或實現。

IDriver -NHibernate.Driver.IDriver:

可選的,驅動接口,用來封裝隱藏不一樣ADO.NET 數據提供程序之間的不一樣。例如:參數化等。

ITransactionFactory - NHibernate.Transaction.ITransactionFactory:

可選的,事務實現工廠,不對應用程序公開,但開發者能夠對其進行擴展或實現。

2. 實例狀態

在NHibernate中,一個可持久化的對象有三種不一樣的狀態,依據與持久化上下文之間的關係不一樣,其中ISession就是一個持久化上下文。狀態分爲如下三種:

  • transient 暫存的、臨時的 該狀態的對象並無被持久化上下文捕獲到,簡單來說就是剛被建立,尚未從數據庫/持久化上下文中獲取到主鍵信息。

  • persistent 持久化的 該狀態的對象表示已經被上下文正確獲取到了,持久化上下文可以監控到對象的變化。持久化上下文中持有一個指向該對象的引用。這種狀態一般是從數據庫中獲取到數據或者新建的數據附加到了上下文中。

  • detached 遊離態 該狀態的對象是從上下文中分離出來的,有了數據庫主鍵,曾經或如今仍然有一條數據庫記錄與之對應。形成的緣由可能有,上下文關閉了;該對象是在另外一個上下文中持久化的,它對於當前上下文是遊離態的。

3. 配置項介紹

在上一篇文章中,咱們介紹了一下如何設置NHibernate的基本配置項,可是並未對配置項進行深刻。這一節,將帶領你們看一下NHibernate中咱們經常使用的配置,由於配置項有不少,但一大部分一般狀況都遇不到使用它的時候。

  • dialect

    數據庫方言,表示NHibernate鏈接的數據庫是什麼,該用哪一種格式解析關係映射到數據庫SQL語句

  • default_schema

    默認的schema,用來設置鏈接字符串鏈接的數據庫默認的schema。

  • connection.provider

    數據庫鏈接的提供程序,默認是NHibernate.Connection.DriverConnectionProvider. 填繼承自 IConnectionProvider 的實現類

  • connection.connection_string

    數據庫鏈接字符串

  • connection.connection_string_name

    數據庫鏈接字符串的名稱,指的是配置在程序的配置文件中 connectionStrings節點的數據鏈接字符串。

  • max_fetch_depth

    最大遞歸深度,表示一次查詢中直接加載的導航屬性深度。默認是不直接加載導航屬性,基於延遲加載的邏輯,由實際使用時才從數據庫中加載數據。

  • show_sql

    是否在控制檯中打印轉換的SQL語句,通常在調試的過程當中會設置爲true,用來確認生成的SQL是否正確等。

  • hbm2ddl.auto

    該值表示每次ISessionFactory建立的時候,是否自動生成DDL語句並提交數據庫執行。默認是空,表示不會強制更新數據庫。有幾個候選值:create或create-drop、update等。其中create表示每次只建立新增的;create-drop表示每次ISessionFactory建立時建立表 ,ISessionFactory關閉時,刪除表;其中update表示每次都會將DDL SQL更新到數據庫中。(我記得有update,但文檔中沒有這個選項)

以上是咱們經常使用的一些配置內容,固然還有更多的配置,我並無在這裏一一講明,留待之後吧。

4. 總結

這是一篇枯燥乏味的說明文,主要介紹了Nhibernate的基本內容。下一章咱們來試試,如何建立Nhibernate的映射配置。

相關文章
相關標籤/搜索