江蘇520

          江蘇520

          常用鏈接

          統計

          最新評論

          JSP頁面查詢顯示常用模式

          背景
          1.    需要將數據庫查詢結果在JSP中以列表方式顯示
          2.    在一個良好的J2EE模式中數據庫查詢一般用DAO實現(Data Access Object), JSP僅用于顯示數據

          問題
              通過JDBC ResultSet可獲取查詢結果(存在于數據庫緩沖區內),但在Statement、Connection關閉后ResultSet即不可用。因此需要一種方式取出所有查詢結果并傳遞至JSP頁面。

          解決方法一
              使用Value Object。將每條記錄均封裝成JavaBean對象,如:http://www.bt285.cn 把這些對象裝入Collection傳送給JSP顯示。這種方法的缺點是每一種查詢都需要定義一個java class,并且將記錄數據封裝成java對象時也需要很多額外的代碼。
          示例代碼:

          1. //查詢數據代碼
          2.   Connection conn = DBUtil.getConnection();
          3.   PreparedStatement pst = null;
          4.   ResultSet rs = null;
          5.   try{
          6.     String sql=“select emp_code, real_name from t_employee where organ_id=?”;
          7.     pst = conn.preparedStatement(sql);
          8.     pst.setString(1, “101”);
          9.     ResultSet rs = pst.executeQuery();
          10.     List list = new ArrayList();
          11.     Employee emp;
          12.     while (rs.next()){
          13.       emp = new Employee();
          14.       emp.setReakName(rs.getString(“real_name”));
          15.       emp.setEmpCode(rs.getString(“emp_code”));
          16.       …
          17.       list.add(emp);
          18.     }
          19.     return list;
          20.   }finally{
          21.     DBUtil.close(rs, pst ,conn);
          22.   }
          23. //jsp顯示部分代碼
          24. <%
          25.   List empList = (List)request.getAttribute(“empList”);
          26.   if (empList == null) empList = Collections.EMPTY_LIST;
          27. %>
          28. <table  cellspacing="0" width=”90%”>
          29.     <tr>  <td> http://www.5a520.cn   小說520網 代碼</td> <td>姓名</td>  </tr>
          30. <%
          31.   Employee emp;
          32.   for (int i=0; i< empList.size(); i++){
          33.     emp = (Employee) empList.get(i);
          34. %>
          35.     <tr>  
          36.       <td><%= emp.getEmpCode()%></td> 
          37.       <td><%= emp.getRealName()%></td>  
          38.     </tr>
          39. <%
          40.   }// end for
          41. %>
          42. </table>


          解決方法二
              遍歷ResultSet取出所有數據封裝進Collection。
          具體做法:
          1.    生成一個List對象(List list = new ArrayList() )。
          2.    生成一個Map對象(Map map = new HashMap() )。使用Map封裝一行數據,key為各字段名,value為對應的值。(map.put(“USER_NAME”), rs.getString(“USER_NAME”))
          3.    將第2 步生成的Map對象裝入第1步的list對象中(list.add(map) )。
          4.    重復2、3步直到ResultSet遍歷完畢
          在DBUtil. resultSetToList(ResultSet rs)方法中實現了上述過程(所有列名均使用大寫),可參考使用。

          示例代碼

          1. //查詢數據部分代碼:
          2.   …
          3.   Connection conn = DBUtil.getConnection();
          4.   PreparedStatement pst = null;
          5.   ResultSet rs = null;
          6.   try{
          7.     String sql=“select emp_code, real_name from t_employee where organ_id=?”;
          8.     pst = conn.preparedStatement(sql);
          9.     pst.setString(1, “101”);
          10.     rs = pst.executeQuery();
          11.     List list = DBUtil. resultSetToList(ResultSet rs);
          12.     return list;
          13.   }finally{
          14.     DBUtil.close(rs, pst ,conn);
          15.   }
          16. //JSP顯示部分代碼
          17. <%
          18.   List empList = (List)request.getAttribute(“empList”);
          19.   if (empList == null) empList = Collections.EMPTY_LIST;
          20. %>
          21. <table  cellspacing="0" width=”90%”>
          22.     <tr>  <td> http://www.feng123.com 蜂蜜 代碼</td> <td>姓名</td>  </tr>
          23. <%
          24.   Map colMap;
          25.   for (int i=0; i< empList.size(); i++){
          26.     colMap = (Map) empList.get(i);
          27. %>
          28.   <tr>  
          29.     <td><%=colMap.get(“EMP_CODE”)%></td> 
          30.     <td><%=colMap.get(“REAL_NAME”)%></td>  
          31.   </tr>
          32. <%
          33.   }// end for
          34. %>
          35. </table>


          解決方法三
              使用RowSet。
          RowSet是JDBC2.0中提供的接口,Oracle對該接口有相應實現,其中很有用的是oracle.jdbc.rowset.OracleCachedRowSet。 OracleCachedRowSet實現了ResultSet中的所有方法,但與ResultSet不同的是,OracleCachedRowSet中的數據在Connection關閉后仍然有效。

          oracle的rowset實現在
          http://otn.oracle.com/software/content.html的jdbc下載里有,名稱是ocrs12.zip

          示例代碼

          1. //查詢數據部分代碼:
          2.   import javax.sql.RowSet;
          3.   import oracle.jdbc.rowset.OracleCachedRowSet;
          4.   …
          5.   Connection conn = DBUtil.getConnection();
          6.   PreparedStatement pst = null;
          7.   ResultSet rs = null;
          8.   try{……
          9.     String sql=“select emp_code, real_name from t_employee where organ_id=?”;
          10.     pst = conn.preparedStatement(sql);
          11.     pst.setString(1, “101”);
          12.     rs = pst.executeQuery();
          13.     OracleCachedRowSet ors = newOracleCachedRowSet();
          14.     //將ResultSet中的數據封裝到RowSet中
          15.     ors.populate(rs);
          16.     return ors;
          17.   }finally{
          18.     DBUtil.close(rs, pst, conn);
          19.   }
          20. //JSP顯示部分代碼
          21. <%
          22.   javax.sql.RowSet empRS = (javax.sql.RowSet) request.getAttribute(“empRS”);
          23. %>
          24. <table  cellspacing="0" width=”90%”>
          25.     <tr>  <td>代碼</td> <td>姓名</td>  </tr>
          26. <%
          27.   if (empRS != nullwhile (empRS.next() ) {
          28. %>
          29.   <tr>  
          30.     <td><%= empRS.get(“EMP_CODE”)%></td> 
          31.     <td><%= empRS.get(“REAL_NAME”)%></td>  
          32.   </tr>
          33. <%
          34.   }// end while
          35. %>
          36. </table>


          適用場合
            方法一使用于定制的查詢操作
            方法二適用于多條查詢語句或需要對查詢結果進行處理的情況。
            方法三適合于單條查詢語句,適用于快速開發。

          posted on 2009-05-27 21:36 江蘇520 閱讀(1623) 評論(0)  編輯  收藏

          主站蜘蛛池模板: 清苑县| 泰州市| 常宁市| 确山县| 田林县| 伊宁县| 鞍山市| 牙克石市| 乌苏市| 宁武县| 雷波县| 东乡县| 尚志市| 和静县| 万年县| 邢台市| 商城县| 化隆| 东乌珠穆沁旗| 平武县| 浮山县| 蒙山县| 丁青县| 彩票| 海伦市| 漯河市| 珠海市| 岱山县| 德保县| 广东省| 蓝田县| 子长县| 阿克陶县| 宁武县| 阜新| 甘洛县| 汝南县| 靖宇县| 麟游县| 深圳市| 河间市|