首先引包:
import jxl.Workbook;
代碼示例:
jxl.Workbook rwb = jxl.Workbook.getWorkbook(new File("C:/Documents and Settings/Administrator/桌面/department.xls"));
jxl.Sheet rs = rwb.getSheet("部門信息"); //sheet名稱,也可以getSheet(0)方法取得sheet
String sheetContext = rs.getCell(1, 0).getContents();
ServletActionContext.getRequest().setAttribute("sheetName", sheetContext);
具體操作見:
http://philos.javaeye.com/blog/90802
posted @
2010-03-09 11:22 lucas_y 閱讀(157) |
評論 (0) |
編輯 收藏
hibenate的面試總結(jié).
可能現(xiàn)在大家常常還會(huì)遇到一個(gè)些面試的時(shí)候問一些關(guān)于hibernate的問題,我個(gè)人覺得,這些東西一般做過開發(fā)的人在使用上沒有任何的問題的,但是如果是要你來說就不一定能夠說好的,下面是從goole上找的一些常見的面試。
1.Hibernate session接口的get和load方法有何異同?
答: get不到實(shí)體對象時(shí)會(huì)返回null,load會(huì)拋出異常
- get會(huì)立即加載實(shí)體對象,load默認(rèn)是延遲加載
- get會(huì)忽略二級緩存(這個(gè)沒有試驗(yàn)過),load則是一級和二級緩存都使用
2.在持久化層,對象分為哪些狀態(tài)?分別列出來.
答:瞬時(shí)態(tài)(Transient)、持久態(tài)(Persistent)、脫管態(tài)(Detached)。
瞬時(shí)態(tài)(Transient)
是對象是創(chuàng)建時(shí),瞬時(shí)對象在內(nèi)存孤立存在,它是攜帶信息的載體,不和數(shù)據(jù)庫的數(shù)據(jù)有任何關(guān)聯(lián)關(guān)系,在Hibernate中,可通過session的save()或 saveOrUpdate()方法將瞬時(shí)對象與數(shù)據(jù)庫相關(guān)聯(lián),并將數(shù)據(jù)對應(yīng)的插入數(shù)據(jù)庫中,此時(shí)該瞬時(shí)對象轉(zhuǎn)變成持久化對象。
持久態(tài)(Persistent)
是該對象在數(shù)據(jù)庫中已有對應(yīng)的記錄,并擁有一個(gè)持久化標(biāo)識,如果是用hibernate的delete()方法,對應(yīng)的持久對象就變成瞬時(shí)對象,因數(shù)據(jù)庫中的對應(yīng)數(shù)據(jù)已被刪除,該對象不再與數(shù)據(jù)庫的記錄關(guān)聯(lián)。
當(dāng)一個(gè)session執(zhí)行close()或clear()、evict()之后,持久對象變成脫管對象,此時(shí)持久對象會(huì)變成脫管對象,此時(shí)該對象雖然具有數(shù)據(jù)庫識別值,但它已不在hibernate持久層的管理之下。
持久對象具有如下特點(diǎn):
1. 和session實(shí)例關(guān)聯(lián);
2. 在數(shù)據(jù)庫中有與之關(guān)聯(lián)的記錄。
脫管態(tài)(Detached)
當(dāng)與某持久對象關(guān)聯(lián)的session被關(guān)閉后,該持久對象轉(zhuǎn)變?yōu)槊摴軐ο蟆.?dāng)脫管對象被重新關(guān)聯(lián)到session上時(shí),并再次轉(zhuǎn)變成持久對象。
脫管對象擁有數(shù)據(jù)庫的識別值,可通過update()、saveOrUpdate()等方法,轉(zhuǎn)變成持久對象。
脫管對象具有如下特點(diǎn):
1.本質(zhì)上與瞬時(shí)對象相同,在沒有任何變量引用它時(shí),JVM會(huì)在適當(dāng)?shù)臅r(shí)候?qū)⑺厥眨?
2. 比瞬時(shí)對象多了一個(gè)數(shù)據(jù)庫記錄標(biāo)識值。
3.lock和update區(qū)別
答: update是把一個(gè)已經(jīng)更改過的脫管狀態(tài)的對象變成持久狀態(tài)
lock是把一個(gè)沒有更改過的脫管狀態(tài)的對象變成持久狀態(tài)(針對的是因Session的關(guān)閉 而處于脫管狀態(tài)的po對象(2),不能針對因delete而處于脫管狀態(tài)的po對象)
對應(yīng)更改一個(gè)記錄的內(nèi)容,兩個(gè)的操作不同:
update的操作步驟是:
(1)屬性改動(dòng)后的脫管的對象的修改->調(diào)用update
lock的操作步驟是:
(2)調(diào)用lock把未修改的對象從脫管狀態(tài)變成持久狀態(tài)-->更改持久狀態(tài)的對象的內(nèi)容-->等待flush或者手動(dòng)flush
4.save 和update區(qū)別
答: save是把一個(gè)對象做為一個(gè)新的數(shù)據(jù)保存, update則是把一個(gè)脫管狀態(tài)的對象或自由態(tài)對象(一定要和一個(gè)記錄對應(yīng))更新到數(shù)據(jù)庫,其實(shí)一個(gè)是保存一個(gè)是更新,一看都知道是有什么區(qū)別了。
5.update 和saveOrUpdate區(qū)別
答:這個(gè)是比較好理解的,顧名思義,saveOrUpdate基本上就是合成了save和update,而update只是update;引用hibernate reference中的一段話來解釋他們的使用場合和區(qū)別
通常下面的場景會(huì)使用update()或saveOrUpdate():
程序在第一個(gè)session中加載對象,接著把session關(guān)閉
該對象被傳遞到表現(xiàn)層
對象發(fā)生了一些改動(dòng)
該對象被返回到業(yè)務(wù)邏輯層最終到持久層
程序創(chuàng)建第二session調(diào)用第二個(gè)session的update()方法持久這些改動(dòng)
saveOrUpdate(po)做下面的事:
如果該po對象已經(jīng)在本session中持久化了,在本session中執(zhí)行saveOrUpdate不做任何事
如果savaOrUpdate(新po)與另一個(gè)與本session關(guān)聯(lián)的po對象擁有相同的持久化標(biāo)識(identifier),拋出一個(gè)異常
org.hibernate.NonUniqueObjectException: a different object with the same identifier value was already associated with the session: [org.itfuture.www.po.Xtyhb#5]
saveOrUpdate如果對象沒有持久化標(biāo)識(identifier)屬性,對其調(diào)用save() ,否則update() 這個(gè)對象
6.flush和update區(qū)別
答:這兩個(gè)的區(qū)別好理解update操作的是在自由態(tài)或脫管狀態(tài)(因session的關(guān)閉而處于脫管狀態(tài))的對象//updateSQL
而flush是操作的在持久狀態(tài)的對象。
默認(rèn)情況下,一個(gè)持久狀態(tài)的對象的改動(dòng)(包含set容器)是不需要update的,只要你更改了對象的值,等待hibernate flush就自動(dòng)更新或保存到數(shù)據(jù)庫了。hibernate flush發(fā)生在以下幾種情況中:
1, 調(diào)用某些查詢的和手動(dòng)flush(),session的關(guān)閉、SessionFactory關(guān)閉結(jié)合
get()一個(gè)對象,把對象的屬性進(jìn)行改變,把資源關(guān)閉。
2,transaction commit的時(shí)候(包含了flush)
posted @
2010-03-08 16:14 lucas_y 閱讀(210) |
評論 (0) |
編輯 收藏