0514-86177077
9:00-17:00(工作日)
1、Configuration/SessionFactory/Session Configuration實例代表了一個應用程序中Java類型 到SQL數據庫映射的完整集合. Configuration被用來構建一個(不可變的 (immutable))SessionFactory. SessionFactory是線程安全的,創建代價很高。 Session是非線程安全的,輕量級的。一個Session對應一個JDBC連接, Session的connection()會獲取Session與之對應的數據庫連接Connection對象。 Session的功能就是操作對象的,這些對象和數據庫表有映射關系。 Session操作的對象是有狀態的,分三類: 自由狀態(transient): 未持久化,未與任何Session相關聯,數據庫表中沒有對應的記錄。 持久化狀態(persistent): 與一個Session相關聯,對應數據庫表中一條記錄。 游離狀態(detached): 已經進行過持久化,但當前未與任何Session相關聯,數據庫表中曾經有一條記錄,現在還有沒有就不知道了。 游離狀態的實例可以通過調用save()、persist()或者saveOrUpdate()方法進行持久化。持久化實例可以通過調用 delete()變成游離狀態。通過get()或load()方法得到的實例都是持久化狀態的。游離狀態的實例可以通過調用 update()、0saveOrUpdate()、lock()或者replicate()進行持久化。游離或者自由狀態下的實例可以通過調用merge()方法成為一個新的持久化實例。 2、Session的save()/persist()/update()/saveOrUpdate()/merge()/delete()方法 save()方法將指定對象保存,插入表中一條數據; persist()方法將指定對象保存,插入表中一條數據,我還沒發現它和save方法有什么特別之處。 replicate()方法完全使用給定對象各個屬性的值(包括標識id)來持久化給定的游離狀態(Transient)的實體,很暴力啊,其中還需要指定存儲模式(有四種保存策略供選擇)。 update()方法將指定對象更新,更新表中一條數據; saveOrUpdate()方法接收一個實體對象,根據實體對象的id判斷是否已經存在進行保存或更新操作,這樣保存和更新方法就統一了; merge()方法將給定的對象的狀態復制到具有相同標識的持久化對象上。 delete()方法將指定對象刪除,刪除表中一條數據; 特別注意:為了使用saveOrUpdate()方法,在由定義映射文件時,通過設定id>標簽的unsaved-value="null"來判斷執行什么操作: 當id屬性等于unsaved-value的值(在此為null)時,則認為還沒有保存,應該執行保存操作,否則執行更新操作。這樣設定之后,可以使用saveOrUpdate()方法來統一保存和更新的方法。 id name="id" column="id" type="java.lang.Integer" unsaved-value="null"> generator class="native"/> /id> unsaved-value可以設定的值有四個: any:總是儲存 none:總是更新 null:id為null時儲存(預設) valid:id為null或是指定值時儲存 3、Session的get()/load()方法 get()方法會總是查詢實體對象,不存在時候返回null; load()方法也是獲取一個實體對象,不存在時候拋空指針異常。 4、Session的clear()/evict()方法 clear()方法清除Session級別緩存中的所有實體(包括各種狀態)對象,目的是釋放內存。 evict()方法清除Session級別緩存中的指定的實體(包括各種狀態)對象。 當然,Session關閉后,這些緩存也就不存在了,會等待JVM回收。 5、Session的flush()方法 flush()強制持久化Session緩存中的實體對象。一般還會調用clear()或evict(),目的是趕緊保存,釋放寶貴內存資源。 6、Session的commit()/rollback()方法 commit()方法用于提交Session上的事務,否則工作單元不會對數據庫產生影響。如果執行出現異常(也就是commit()失敗了),則之前的操作取消,執行rollback()可撤消之前的操作。 7、Session的close()/isOpen()/isConnected()/reconnect()方法 close()方法關閉Session所對應數據庫連接,與其相關聯的對象生命周期結束。 isOpen()方法檢查Session是否仍然打開,如果Session已經斷開,則可以使用reconnect(Connection connection)來重新讓Session關聯一個JDBC連接。 isConnected()方法檢查當前Session是否處于連接狀態。 8、Criteria、DetchedCriteria和Query接口 Criteria和Query的實例都是和Session綁定的,其生命周期跟隨著Session結束而結束。 DetchedCriteria實例相當于一個SQL模板,目的是為了復用。其中的getExecutableCriteria(session)方法接收一個Session對象,并與之綁定,返回一個Criteria對象。 9、Hibernate類的initialize()方法 initialize()方法強制Hibernate立即加載指定實體所關聯的對象和集合。Hibernate類中還有其他幾個很有用但不適很常用的方法。 10、映射文件中的lazy屬性 在Hibernate3中,class元素的lazy屬性默認是true,如果不需要,則需要顯示指定為lazy="false",否則,操作load返回的對象會拋異常。另外Hibernate3中還可以為實體屬性指定lazy屬性。 11、JDBC事務和JTA事務 Hibernate本身沒有事務管理功能,它依賴于JDBC或JTA的事務管理功能,在Hibernate配置文件中,如果不顯式指定Transaction的工廠類別屬性hibernate.transaction.factory_class的配置,則默認為JDBC事務: property name="hibernate.transaction.factory_class">org.hibernate.transaction.JDBCTransactionFactory/property>。 在通過SessionFactory獲取到Session后,與Session相關聯的JDBC Connection實例就被設定為false。 特別注意:如果數據庫不支持事務,比如MySQL的MyISAM引擎的表就不支持事務,聲明事務也不會起作用。要使MySQL5的表支持事務,則可以指定表的引擎類型為InnoDB。如果是學習或者研究,目前最好還是使用PostgreSQL 8.3或DB2、Oracle。 JDBC事務總是和一個數據庫連接(或一個Session)相關聯的。 JTA事務則可以跨越多個數據連接(或多個Session),這些連接還可以是不同數據庫的連接,JTA事務一般由容器進行管理。編程只要在多個操作單元的開始和結束定義JTA事務的邊界即可。 特別注意:如果使用了JTA事務,則不能再用在JDBC式的事務來管理每個Session的操作,否則會出錯。為了程序的的通用性,一般來說,都是使用JTA事務來構建應用,這使用任何環境。當然,也可以使用事務代理為每個JDBC的操作方法加入事務控制。這樣也為程序以后移植到JTA容器事務上帶來很大方便。其實現在可以使用Spring的事務管理,與Hibernate結合的非常完美。 PS:persist()方法無返回值,save()方法返回對象標識符。 persist()方法只能保存暫態和持久態的對象,save()方法能保存任何狀態對象。 共同點:調用完方法后,對象的狀態都變成持久態。 get()方法返回對象的實例,而對于load()方法,如果在持久化上下文存在該標識符的對象,就返回該對象的實例,否則返回對象的代理,該代理對象只含有對象標識符。 使用get或load要小心 load可以提高緩存使用效率 但由于是代理 所以在后面操作會更容易出現問題 get是直接訪問db 所以cache的作用就沒了 但會馬上得到結果 麻煩少,但頻繁調用勢必對服務器壓力增加
標簽:馬鞍山 紅河 大興安嶺 武威 岳陽 鄭州 亳州 拉薩
上一篇:jsp hibernate 數據保存操作的原理
下一篇:Hibernate通用數據庫操作代碼
Copyright ? 1999-2012 誠信 合法 規范的巨人網絡通訊始建于2005年
蘇ICP備15040257號-8