隨筆 - 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 閱讀(154) | 評論 (0)編輯 收藏
          hibenate的面試總結.
          可能現在大家常常還會遇到一個些面試的時候問一些關于hibernate的問題,我個人覺得,這些東西一般做過開發的人在使用上沒有任何的問題的,但是如果是要你來說就不一定能夠說好的,下面是從goole上找的一些常見的面試。
          1.Hibernate session接口的get和load方法有何異同?
          答: get不到實體對象時會返回null,load會拋出異常
            - get會立即加載實體對象,load默認是延遲加載
            - get會忽略二級緩存(這個沒有試驗過),load則是一級和二級緩存都使用

          2.在持久化層,對象分為哪些狀態?分別列出來.
          答:瞬時態(Transient)、持久態(Persistent)、脫管態(Detached)。
          瞬時態(Transient)
          是對象是創建時,瞬時對象在內存孤立存在,它是攜帶信息的載體,不和數據庫的數據有任何關聯關系,在Hibernate中,可通過session的save()或 saveOrUpdate()方法將瞬時對象與數據庫相關聯,并將數據對應的插入數據庫中,此時該瞬時對象轉變成持久化對象。
          持久態(Persistent)
          是該對象在數據庫中已有對應的記錄,并擁有一個持久化標識,如果是用hibernate的delete()方法,對應的持久對象就變成瞬時對象,因數據庫中的對應數據已被刪除,該對象不再與數據庫的記錄關聯。
              當一個session執行close()或clear()、evict()之后,持久對象變成脫管對象,此時持久對象會變成脫管對象,此時該對象雖然具有數據庫識別值,但它已不在hibernate持久層的管理之下。
            持久對象具有如下特點:
               1. 和session實例關聯;
               2. 在數據庫中有與之關聯的記錄。
          脫管態(Detached)
          當與某持久對象關聯的session被關閉后,該持久對象轉變為脫管對象。當脫管對象被重新關聯到session上時,并再次轉變成持久對象。
                 脫管對象擁有數據庫的識別值,可通過update()、saveOrUpdate()等方法,轉變成持久對象。
                 脫管對象具有如下特點:
            1.本質上與瞬時對象相同,在沒有任何變量引用它時,JVM會在適當的時候將它回收;
          2. 比瞬時對象多了一個數據庫記錄標識值。

          3.lock和update區別
          答: update是把一個已經更改過的脫管狀態的對象變成持久狀態
          lock是把一個沒有更改過的脫管狀態的對象變成持久狀態(針對的是因Session的關閉 而處于脫管狀態的po對象(2),不能針對因delete而處于脫管狀態的po對象)
          對應更改一個記錄的內容,兩個的操作不同:
          update的操作步驟是:
          (1)屬性改動后的脫管的對象的修改->調用update
          lock的操作步驟是:
          (2)調用lock把未修改的對象從脫管狀態變成持久狀態-->更改持久狀態的對象的內容-->等待flush或者手動flush

          4.save 和update區別
          答: save是把一個對象做為一個新的數據保存, update則是把一個脫管狀態的對象或自由態對象(一定要和一個記錄對應)更新到數據庫,其實一個是保存一個是更新,一看都知道是有什么區別了。

          5.update 和saveOrUpdate區別
          答:這個是比較好理解的,顧名思義,saveOrUpdate基本上就是合成了save和update,而update只是update;引用hibernate reference中的一段話來解釋他們的使用場合和區別
          通常下面的場景會使用update()或saveOrUpdate():
          程序在第一個session中加載對象,接著把session關閉
          該對象被傳遞到表現層
          對象發生了一些改動
          該對象被返回到業務邏輯層最終到持久層
          程序創建第二session調用第二個session的update()方法持久這些改動
          saveOrUpdate(po)做下面的事:
          如果該po對象已經在本session中持久化了,在本session中執行saveOrUpdate不做任何事
          如果savaOrUpdate(新po)與另一個與本session關聯的po對象擁有相同的持久化標識(identifier),拋出一個異常
          org.hibernate.NonUniqueObjectException: a different object with the same identifier value was already associated with the session: [org.itfuture.www.po.Xtyhb#5]
          saveOrUpdate如果對象沒有持久化標識(identifier)屬性,對其調用save() ,否則update() 這個對象     

          6.flush和update區別
          答:這兩個的區別好理解update操作的是在自由態或脫管狀態(因session的關閉而處于脫管狀態)的對象//updateSQL
          而flush是操作的在持久狀態的對象。
          默認情況下,一個持久狀態的對象的改動(包含set容器)是不需要update的,只要你更改了對象的值,等待hibernate flush就自動更新或保存到數據庫了。hibernate flush發生在以下幾種情況中:
          1, 調用某些查詢的和手動flush(),session的關閉、SessionFactory關閉結合
          get()一個對象,把對象的屬性進行改變,把資源關閉。
          2,transaction commit的時候(包含了flush)
          posted @ 2010-03-08 16:14 lucas_y 閱讀(207) | 評論 (0)編輯 收藏
          主站蜘蛛池模板: 思南县| 江北区| 诏安县| 衡南县| 河源市| 镇赉县| 油尖旺区| 寿宁县| 水富县| 永宁县| 上栗县| 襄城县| 岳池县| 扶余县| 石狮市| 定远县| 沽源县| 东乌| 波密县| 通道| 乌兰县| 清水县| 新津县| 湖北省| 突泉县| 霍城县| 始兴县| 杭州市| 黄陵县| 亳州市| 梁河县| 房山区| 禹州市| 金秀| 平谷区| 保德县| 苍山县| 衡阳市| 旬邑县| 错那县| 宁强县|