程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> JSP編程 >> 關於JSP >> jsp Hibernate 函數簡介

jsp Hibernate 函數簡介

編輯:關於JSP

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的作用就沒了 但會馬上得到結果 麻煩少,但頻繁調用勢必對服務器壓力增加

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved