隨筆-1  評論-0  文章-1  trackbacks-0
            2006年4月7日
          Hibernate的透明持久化用起來非常舒服,有時甚至忘記了數據庫的存在。我身邊的朋友經常會分不清save、saveOrUpdate、update的區別,lock、merge、replicate、refresh、evict甚至不知道是干什么用的。而且關于實體對象的生命周期也有很多概念不清,分不清transient、persistent、detached的區別,只是知道PO、VO這樣的通俗叫法。其實這些概念都很簡單,Hibernate的javadoc寫的都很清楚,只需看看就能明白。所以我花了些時間將Hibernate 3.1.2中session的javadoc部分翻譯了一下,旨在讓那些因為Hibernate的“透明”而忘記了它基本概念的人們停下來再看看這些概念


          org.hibernate
          Interface Session

          All Superinterfaces:
          Serializable
          All Known Subinterfaces:
          EventSource, Session
          All Known Implementing Classes:
          SessionImpl

          public interface Session
          extends Serializable

          Java應用程序與Hibernate之間的主要運行時接口。它是抽象了持久化服務概念的核心抽象API類。

          Session的生命周期綁定在一個物理的事務(tansaction)上面。(長的事務可能跨越多個數據庫事物。)

          Session的主要功能是提供對映射的實體類實例的創建,讀取和刪除操作。實例可能以下面三種狀態存在:

          自由狀態(transient): 不曾進行持久化,未與任何Session相關聯
          持久化狀態(persistent): 僅與一個Session相關聯
          游離狀態(detached): 已經進行過持久化,但當前未與任何Session相關聯

          游離狀態的實例可以通過調用save()persist()或者saveOrUpdate()方法進行持久化。持久化實例可以通過調用 delete()變成游離狀態。通過get()load()方法得到的實例都是持久化狀態的。游離狀態的實例可以通過調用 update()、0saveOrUpdate()lock()或者replicate()進行持久化。游離或者自由狀態下的實例可以通過調用merge()方法成為一個新的持久化實例。

          save()persist()將會引發SQL的INSERTdelete()會引發SQLDELETE,而update()merge()會引發SQLUPDATE。對持久化(persistent)實例的修改在刷新提交的時候會被檢測到,它也會引起SQLUPDATEsaveOrUpdate()或者replicate()會引發SQLINSERT或者UPDATE

          其具體實現并不一定是線程安全的。每個線程/事務應該從一個SessionFactory獲取自己的session實例。

          如果其持久化對象類是可序列化的,則Session實例也是可序列化的。

          一個典型的事務應該使用下面的形式:

           Session sess = factory.openSession();
           Transaction tx;
           try {
               tx = sess.beginTransaction();
               //do some work
               ...
               tx.commit();
           }
           catch (Exception e) {
               if (tx!=null) tx.rollback();
               throw e;
           }
           finally {
               sess.close();
           }
           

          如果Session拋出了異常, 事務必須回滾而session會被廢棄。在異常發生后Session的內部狀態可能會與數據庫失去同步。

          Author:
          Gavin King
          See Also:
          SessionFactory


          Method Summary
          ?TransactionbeginTransaction()
          ??????????開始一個工作單元并且返回相關聯的事務(Transaction)對象。
          ?voidcancelQuery()
          ??????????終止執行當前查詢。
          ?voidclear()
          ??????????完整的清除這個session。
          ?Connectionclose()
          ??????????停止這個Session,通過中斷JDBC連接并且清空(cleaning up)它。
          ?Connectionconnection()
          ??????????獲取這個Session的JDBC連接。

          如果這個session使用了積極的collection釋放策略(如CMT-容器控制事務的環境下),關閉這個調用的連接的職責應該由當前應用程序負責。
          ?booleancontains(Object?object)
          ??????????檢查這個對象實例是否與當前的Session關聯(即是否為Persistent狀態)。
          ?CriteriacreateCriteria(Class?persistentClass)
          ??????????為給定的實體類或它的超類創建一個新的Criteria實例。
          ?CriteriacreateCriteria(Class?persistentClass, String?alias)
          ??????????根據給定的實體類或者它的超類創建一個新的Criteria實例,并賦予它(實體類)一個別名。
          ?CriteriacreateCriteria(String?entityName)
          ??????????根據給定的實體的名稱(name),創建一個新的Criteria實例。
          ?CriteriacreateCriteria(String?entityName, String?alias)
          ??????????根據給定的實體的名稱(name),創建一個新的Criteria實例,并賦予它(實體類)一個別名
          ?QuerycreateFilter(Object?collection, String?queryString)
          ??????????根據給定的collection和過濾字符串(查詢條件)創建一個新的Query實例。
          ?QuerycreateQuery(String?queryString)
          ??????????根據給定的HQL查詢條件創建一個新的Query實例。
          ?SQLQuerycreateSQLQuery(String?queryString)
          ??????????根據給定的SQL查詢條件創建一個新的SQLQuery實例。
          ?voiddelete(Object?object)
          ??????????從數據庫中移除持久化(persistent)對象的實例。
          ?voiddelete(String?entityName, Object?object)
          ??????????從數據庫中移除持久化(persistent)對象的實例。
          ?voiddisableFilter(String?filterName)
          ??????????禁用當前session的名稱過濾器。
          ?Connectiondisconnect()
          ??????????斷開Session與當前的JDBC連接。
          ?FilterenableFilter(String?filterName)
          ??????????打開當前session的名稱過濾器。
          ?voidevict(Object?object)
          ??????????將當前對象實例從session緩存中清除。
          ?voidflush()
          ??????????強制提交刷新(flush)Session
          ?Objectget(Class?clazz, Serializable?id)
          ??????????根據給定標識和實體類返回持久化對象的實例,如果沒有符合條件的持久化對象實例則返回null。
          ?Objectget(Class?clazz, Serializable?id, LockMode?lockMode)
          ??????????根據給定標識和實體類返回持久化對象的實例,如果沒有符合條件的持久化對象實例則返回null。
          ?Objectget(String?entityName, Serializable?id)
          ??????????返回與給定的實體命名和標識匹配的持久化實例,如果沒有對應的持久化實例則返回null。
          ?Objectget(String?entityName, Serializable?id, LockMode?lockMode)
          ??????????返回與給定的實體類和標識所匹配的持久化實例,如果沒有對應的持久化實例則返回null。
          ?CacheModegetCacheMode()
          ??????????得到當前的緩存模式。
          ?LockModegetCurrentLockMode(Object?object)
          ??????????檢測給定對象當前的鎖定級別。
          ?FiltergetEnabledFilter(String?filterName)
          ??????????根據名稱獲取一個當前允許的過濾器(filter)。
          ?EntityModegetEntityMode()
          ??????????獲取這個session有效的實體模式。
          ?StringgetEntityName(Object?object)
          ??????????返回一個持久化對象的實體名稱。
          ?FlushModegetFlushMode()
          ??????????獲得當前的刷新提交(flush)模式。
          ?SerializablegetIdentifier(Object?object)
          ??????????獲取給定的實體對象實例在Session的緩存中的標識,如果該實例是自由狀態(Transient)的或者與其它Session關聯則拋出一個異常。
          ?QuerygetNamedQuery(String?queryName)
          ??????????從映射文件中根據給定的查詢的名稱字符串獲取一個Query(查詢)實例。
          ?SessiongetSession(EntityMode?entityMode)
          ??????????根據給定的實體模式(Entity Mode)開始一個新的有效的Session。
          ?SessionFactorygetSessionFactory()
          ??????????獲取創建這個session的SessionFactory實例。
          ?SessionStatisticsgetStatistics()
          ??????????獲取這個session的統計信息。
          ?TransactiongetTransaction()
          ??????????獲取與這個session關聯的Transaction(事務)實例。 instance associated with this session.
          ?booleanisConnected()
          ??????????檢查當前Session是否處于連接狀態。
          ?booleanisDirty()
          ??????????當前Session是否包含需要與數據庫同步的(數據狀態)變化 ?如果我們刷新提交(flush)這個session是否會有SQL執行?
          ?booleanisOpen()
          ??????????檢查當前Session是否仍然打開。
          ?Objectload(Class?theClass, Serializable?id)
          ??????????在符合條件的實例存在的情況下,根據給定的實體類和標識返回持久化狀態的實例。
          ?Objectload(Class?theClass, Serializable?id, LockMode?lockMode)
          ??????????在符合條件的實例存在的情況下,根據給定的實體類、標識及指定的鎖定等級返回持久化狀態的實例。
          ?voidload(Object?object, Serializable?id)
          ??????????將與給定的標示對應的持久化狀態(值)復制到給定的自由狀態(trasient)實例上。
          ?Objectload(String?entityName, Serializable?id)
          ??????????在符合條件的實例存在的情況下,根據給定的實體類和標識返回持久化狀態的實例。
          ?Objectload(String?entityName, Serializable?id, LockMode?lockMode)
          ??????????在符合條件的實例存在的情況下,根據給定的實體類、標識及指定的鎖定等級返回持久化狀態的實例。
          ?voidlock(Object?object, LockMode?lockMode)
          ??????????從給定的對象上獲取指定的鎖定級別。
          ?voidlock(String?entityName, Object?object, LockMode?lockMode)
          ??????????從給定的對象上獲取指定的鎖定級別。
          ?Objectmerge(Object?object)
          ??????????將給定的對象的狀態復制到具有相同標識的持久化對象上。
          ?Objectmerge(String?entityName, Object?object)
          ??????????將給定的對象的狀態復制到具有相同標識的持久化對象上。
          ?voidpersist(Object?object)
          ??????????將一個自由狀態(transient)的實例持久化。
          ?voidpersist(String?entityName, Object?object)
          ??????????將一個自由狀態(transient)的實例持久化。
          ?voidreconnect()
          ??????????不推薦的。?手工的重新連接只應用于應用程序提供連接的情況,在這種情況下或許應該使用reconnect(java.sql.Connection)
          ?voidreconnect(Connection?connection)
          ??????????重新連接到給定的JDBC連接。
          ?voidrefresh(Object?object)
          ??????????從數據庫中重新讀取給定實例的狀態。
          ?voidrefresh(Object?object, LockMode?lockMode)
          ??????????根據指定的鎖定模式(LockMode),從數據庫中重新讀取給定實例的狀態。
          ?voidreplicate(Object?object, ReplicationMode?replicationMode)
          ??????????使用當前的標識值持久化給定的游離狀態(Transient)的實體。
          ?voidreplicate(String?entityName, Object?object, ReplicationMode?replicationMode)
          ??????????使用當前的標識值持久化給定的游離狀態(Transient)的實體。
          ?Serializablesave(Object?object)
          ??????????首先為給定的自由狀態(Transient)的對象(根據配置)生成一個標識并賦值,然后將其持久化。
          ?Serializablesave(String?entityName, Object?object)
          ??????????首先為給定的自由狀態(Transient)的對象(根據配置)生成一個標識并賦值,然后將其持久化。
          ?voidsaveOrUpdate(Object?object)
          ??????????根據給定的實例的標識屬性的值(注:可以指定unsaved-value。一般默認null。)來決定執行 save()update()操作。
          ?voidsaveOrUpdate(String?entityName, Object?object)
          ??????????根據給定的實例的標識屬性的值(注:可以指定unsaved-value。一般默認null。)來決定執行 save()update()操作。
          ?voidsetCacheMode(CacheMode?cacheMode)
          ??????????設置刷新提交模式。
          ?voidsetFlushMode(FlushMode?flushMode)
          ??????????設置刷新提交模式。
          ?voidsetReadOnly(Object?entity, boolean?readOnly)
          ??????????將一個未經更改的持久化對象設置為只讀模式,或者將一個只讀對象標記為可以修改的模式。
          ?voidupdate(Object?object)
          ??????????根據給定的detached(游離狀態)對象實例的標識更新對應的持久化實例。
          ?voidupdate(String?entityName, Object?object)
          ??????????根據給定的detached(游離狀態)對象實例的標識更新對應的持久化實例。
          ?

          from:http://www.aygfsteel.com/iamtin/archive/2006/03/06/33910.html

          posted @ 2006-04-07 22:04 博客java 閱讀(255) | 評論 (0)編輯 收藏
          主站蜘蛛池模板: 五台县| 龙川县| 临洮县| 黔南| 射洪县| 沛县| 改则县| 牡丹江市| 赤城县| 宁阳县| 房山区| 密山市| 汤原县| 昆山市| 金山区| 余姚市| 正镶白旗| 龙里县| 延长县| 贵德县| 扬中市| 梅河口市| 金坛市| 育儿| 安龙县| 金溪县| 乌兰浩特市| 绥宁县| 左权县| 大足县| 包头市| 青川县| 靖宇县| 三亚市| 军事| 二连浩特市| 武威市| 武川县| 清流县| 普宁市| 蒙自县|