隨筆 - 18  文章 - 0  trackbacks - 0
          <2010年3月>
          28123456
          78910111213
          14151617181920
          21222324252627
          28293031123
          45678910

          常用鏈接

          留言簿

          隨筆分類

          隨筆檔案

          搜索

          •  

          最新評論

          閱讀排行榜

          評論排行榜

          首先引包:
              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)編輯 收藏
          主站蜘蛛池模板: 陕西省| 集安市| 基隆市| 牡丹江市| 民权县| 南宫市| 龙南县| 丁青县| 岫岩| 安丘市| 万安县| 武陟县| 安顺市| 临夏市| 乐亭县| 宁海县| 临江市| 津南区| 盐池县| 布拖县| 临清市| 乡宁县| 开鲁县| 西吉县| 大渡口区| 嘉鱼县| 桐乡市| 理塘县| 周宁县| 临沧市| 通城县| 额尔古纳市| 互助| 新化县| 武山县| 象州县| 甘孜县| 榆林市| 永清县| 和林格尔县| 南汇区|