亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > Oracle > 正文

Oracle下的Java分頁功能_動力節點Java學院整理

2024-08-29 14:00:27
字體:
來源:轉載
供稿:網友

就如平時我們很在分頁中看到的,分頁的時候返回的不僅包括查詢的結果集(List),而且還包括總的頁數(pageNum)、當前第幾頁(pageNo)等等信息,所以我們封裝一個查詢結果PageModel類,代碼如下:

package com.bjpowernode.test; import java.util.List; public class PageModel<E> {  private List<E> list;  private int pageNo;  private int pageSize;  private int totalNum;  private int totalPage;  public List<E> getList() {  return list;  }  public void setList(List<E> list) {  this.list = list;  }  public int getPageNo() {  return pageNo;  }  public void setPageNo(int pageNo) {  this.pageNo = pageNo;  }  public int getPageSize() {  return pageSize;  }  public void setPageSize(int pageSize) {  this.pageSize = pageSize;  }  public int getTotalNum() {  return totalNum;  }  public void setTotalNum(int totalNum) {  this.totalNum = totalNum;  setTotalPage((getTotalNum() % pageSize) == 0 ? (getTotalNum() / pageSize)   : (getTotalNum() / pageSize + 1));  }  public int getTotalPage() {  return totalPage;  }  public void setTotalPage(int totalPage) {  this.totalPage = totalPage;  }  // 獲取第一頁  public int getFirstPage() {  return 1;  }  // 獲取最后頁  public int getLastPage() {  return totalPage;  }  // 獲取前頁  public int getPrePage() {  if (pageNo > 1)   return pageNo - 1;  return 1;  }  // 獲取后頁  public int getBackPage() {  if (pageNo < totalPage)   return pageNo + 1;  return totalPage;  }  // 判斷'首頁'及‘前頁'是否可用  public String isPreable() {  if (pageNo == 1)   return "disabled";  return "";  }  // 判斷'尾頁'及‘下頁'是否可用  public String isBackable() {  if (pageNo == totalPage)   return "disabled";  return "";  } } 

  其中使用泛型是為了能使的該分頁類能進行重用,比如在查詢用戶時可以封裝User對象、在查詢財務中的流向單時可以封裝流向單FlowCard類。 

  我們以查詢用戶為例,用戶選擇查詢條件,首先調用Servlet獲取查詢參數,然后請求業務邏輯層取得分頁封裝結果類。業務邏輯調用Dao層取得結果集、取得中記錄數封裝成分頁類。最后Servlet將結果設置到jsp頁面顯示。

  首先來講解Servlet,代碼如下:

package com.bjpowernode.test; import java.io.*; import java.util.*; import javax.servlet.ServletConfig; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import kane.UserInfo; import kane.UserInfoManage; import kane.PageModel; public class UserBasicSearchServlet extends HttpServlet {  private static final long serialVersionUID = 1L;  private int pageSize = 0;  @Override  public void init(ServletConfig config) throws ServletException {  pageSize = Integer.parseInt(config.getInitParameter("pageSize"));  }  @Override  protected void doGet(HttpServletRequest req, HttpServletResponse resp)   throws ServletException, IOException {  doPost(req, resp);  }  @Override  protected void doPost(HttpServletRequest req, HttpServletResponse resp)   throws ServletException, IOException {  // 1.取得頁面參數并構造參數對象  int pageNo = Integer.parseInt(req.getParameter("pageNo"));  String sex = req.getParameter("gender");  String home = req.getParameter("newlocation");  String colleage = req.getParameter("colleage");  String comingyear = req.getParameter("ComingYear");  UserInfo u = new UserInfo();  u.setSex(sex);  u.setHome(home);  u.setColleage(colleage);  u.setCy(comingyear);  // 2.調用業務邏輯取得結果集  UserInfoManage userInfoManage = new UserInfoManage();  PageModel<UserInfo> pagination = userInfoManage.userBasicSearch(u,   pageNo, pageSize);  List<UserInfo> userList = pagination.getList();  // 3.封裝返回結果  StringBuffer resultXML = new StringBuffer();  try {   resultXML.append("<?xml version='1.0' encoding='gb18030'?>/n");   resultXML.append("<root>/n");   for (Iterator<UserInfo> iterator = userList.iterator(); iterator    .hasNext();) {   UserInfo userInfo = iterator.next();   resultXML.append("<data>/n");   resultXML.append("/t<id>" + userInfo.getId() + "</id>/n");   resultXML.append("/t<truename>" + userInfo.getTruename()    + "</ truename >/n");   resultXML.append("/t<sex>" + userInfo.getSex() + "</sex>/n");   resultXML.append("/t<home>" + userInfo.getHome() + "</home>/n");   resultXML.append("</data>/n");   }   resultXML.append("<pagination>/n");   resultXML.append("/t<total>" + pagination.getTotalPage()    + "</total>/n");   resultXML.append("/t<start>" + pagination.getFirstPage()    + "</start>/n");   resultXML.append("/t<end>" + pagination.getLastPage() + "</end>/n");   resultXML.append("/t<pageno>" + pagination.getPageNo()    + "</pageno>/n");   resultXML.append("</pagination>/n");   resultXML.append("</root>/n");  } catch (Exception e) {   e.printStackTrace();  }  writeResponse(req, resp, resultXML.toString());  }  public void writeResponse(HttpServletRequest request,   HttpServletResponse response, String result) throws IOException {  response.setContentType("text/xml");  response.setHeader("Cache-Control", "no-cache");  response.setHeader("Content-Type", "text/xml; charset=gb18030");  PrintWriter pw = response.getWriter();  pw.write(result);  pw.close();  } } 

其中User對象代碼如下:

package com.bjpowernode.test; import java.util.Date; public class UserInfo {  private int id;  private String username;  private String password;  private String truename;  private String sex;  private Date birthday;  private String home;  private String colleage;  private String comingYear;  public int getId() {  return id;  }  public void setId(int id) {  this.id = id;  }  public String getUsername() {  return username;  }  public void setUsername(String username) {  this.username = username;  }  public String getPassword() {  return password;  }  public void setPassword(String password) {  this.password = password;  }  public String getTruename() {  return truename;  }  public void setTruename(String truename) {  this.truename = truename;  }  public String getSex() {  return sex;  }  public void setSex(String sex) {  this.sex = sex;  }  public Date getBirthday() {  return birthday;  }  public void setBirthday(Date birthday) {  this.birthday = birthday;  }  public String getHome() {  return home;  }  public void setHome(String home) {  this.home = home;  }  public String getColleage() {  return colleage;  }  public void setColleage(String colleage) {  this.colleage = colleage;  }  public String getCy() {  return comingYear;  }  public void setCy(String cy) {  this. comingYear= cy;  } } 

接著是業務邏輯層代碼,代碼如下:

package com.bjpowernode.test; import java.sql.Connection; import kane.DBUtility; import kane.PageModel; public class UserInfoManage {  private UserInfoDao userInfoDao = null;  public UserInfoManage () {  userInfoDao = new UserInfoDao();  }  public PageModel<UserInfo> userBasicSearch(UserInfo u, int pageNo,   int pageSize) throws Exception {  Connection connection = null;  PageModel<UserInfo> pagination = new PageModel<UserInfo>();  try {   connection = DBUtility.getConnection();   DBUtility.setAutoCommit(connection, false);   pagination.setList(userInfoDao.getUserList(u, pageNo, pageSize));   pagination.setPageNo(pageNo);   pagination.setPageSize(pageSize);   pagination.setTotalNum(userInfoDao.getTotalNum(u));   DBUtility.commit(connection);  } catch (Exception e) {   DBUtility.rollBack(connection);   e.printStackTrace();   throw new Exception();  } finally {   DBUtility.closeConnection();  }  return pagination;  } } 

其中DBUtility為數據庫的連接封裝類。

最后是Dao層代碼實現,代碼如下: 

package com.bjpowernode.test; import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import java.util.ArrayList; import java.util.List; import kane.UserInfo; import kane.DBUtility; public class UserInfoDao {  public List<UserInfo> getUserList(UserInfo userInfo, int pageNo,   int pageSize) throws Exception {  PreparedStatement pstmt = null;  ResultSet rs = null;  List<UserInfo> userList = null;  try {   String sql = "select * from(select rownum num,u.* from(select * from user_info where sex = ? and home like '"    + userInfo.getHome()    + "%"    + "' and colleage like '"    + userInfo.getColleage()    + "%"    + "' and comingyear like '"    + userInfo.getCy()    + "%"    + "' order by id) u where rownum<=?) where num>=?";   userList = new ArrayList<UserInfo>();   Connection conn = DBUtility.getConnection();   pstmt = conn.prepareStatement(sql);   pstmt.setString(1, userInfo.getSex());   pstmt.setInt(2, pageNo * pageSize);   pstmt.setInt(3, (pageNo - 1) * pageSize + 1);   rs = pstmt.executeQuery();   while (rs.next()) {   UserInfo user = new UserInfo();   user.setId(rs.getInt("id"));   user.setTruename(rs.getString("truename"));   user.setSex(rs.getString("sex"));   user.setHome(rs.getString("home"));   userList.add(user);   }  } catch (SQLException e) {   e.printStackTrace();   throw new Exception(e);  } finally {   DBUtility.closeResultSet(rs);   DBUtility.closePreparedStatement(pstmt);  }  return userList;  }  public int getTotalNum(UserInfo userInfo) throws Exception {  PreparedStatement pstmt = null;  ResultSet rs = null;  int count = 0;  try {   String sql = "select count(*) from user_info where sex=? and home like '"    + userInfo.getHome()    + "%"    + "' and colleage like '"    + userInfo.getColleage()    + "%"    + "' and comingyear like '"    + userInfo.getCy()+ "%" + "'";   Connection conn = DBUtility.getConnection();   pstmt = conn.prepareStatement(sql);   pstmt.setString(1, userInfo.getSex());   rs = pstmt.executeQuery();   if (rs.next()) {   count = rs.getInt(1);   }  } catch (SQLException e) {   e.printStackTrace();   throw new Exception(e);  } finally {   DBUtility.closeResultSet(rs);   DBUtility.closePreparedStatement(pstmt);  }  return count;  } } 

最后就是servlet將得到的結果返回給jsp頁面顯示出來。

注:其中DBUtility代碼是封裝數據庫連接操作的代碼,如下:

1.package com.bjpowernode.test;    

import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; public class DBUtility {  private static ThreadLocal<Connection> threadLocal = new ThreadLocal<Connection>();  public static Connection getConnection() {  Connection conn = null;  conn = threadLocal.get();  if (conn == null) {   try {   Class.forName("oracle.jdbc.driver.OracleDriver");   conn = DriverManager.getConnection(    "jdbc:oracle:thin:@localhost:1521:oracle", "admin",    "admin");   threadLocal.set(conn);   } catch (ClassNotFoundException e) {   e.printStackTrace();   } catch (SQLException e) {   e.printStackTrace();   }  }  return conn;  }  // 封裝設置Connection自動提交  public static void setAutoCommit(Connection conn, Boolean flag) {  try {   conn.setAutoCommit(flag);  } catch (SQLException e) {   e.printStackTrace();  }  }  // 設置事務提交  public static void commit(Connection conn) {  try {   conn.commit();  } catch (SQLException e) {   e.printStackTrace();  }  }  // 封裝設置Connection回滾  public static void rollBack(Connection conn) {  try {   conn.rollback();  } catch (SQLException e) {   e.printStackTrace();  }  }  // 封裝關閉Connection、PreparedStatement、ResultSet的函數  public static void closeConnection() {  Connection conn = threadLocal.get();  try {   if (conn != null) {   conn.close();   conn = null;   threadLocal.remove();   }  } catch (SQLException e) {   e.printStackTrace();  }  }  public static void closePreparedStatement(PreparedStatement pstmt) {  try {   if (pstmt != null) {   pstmt.close();   pstmt = null;   }  } catch (SQLException e) {   e.printStackTrace();  }  }  public static void closeResultSet(ResultSet rs) {  try {   if (rs != null) {   rs.close();   rs = null;   }  } catch (SQLException e) {   e.printStackTrace();  }  } } 

使用ThreadLocal是為了保證事務的一致,使得同一個線程的所有數據庫操作使用同一個Connection。

到此一個簡單的代碼實現就完成了。

總結

以上所述是小編給大家介紹的Oracle下的Java分頁功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對VeVb武林網網站的支持!


注:相關教程知識閱讀請移步到oracle教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91亚洲人电影| 亚洲精品视频在线观看视频| 亚洲天堂av高清| 亚洲精品欧美日韩专区| 亚洲男人第一av网站| 欧美精品videos性欧美| 欧美福利在线观看| 国产精品久久久久久久app| 91精品国产自产在线老师啪| 欧美黄色片免费观看| 中文字幕无线精品亚洲乱码一区| 在线看片第一页欧美| 欧美日韩成人在线播放| 91精品国产综合久久香蕉最新版| 欧美日韩国产中文精品字幕自在自线| 欧美激情第99页| 亚洲欧美国内爽妇网| 欧美激情中文网| 日韩网站免费观看| 黄网站色欧美视频| 国产丝袜一区二区三区免费视频| 亚洲免费中文字幕| 91成人福利在线| 欧美激情亚洲国产| 91欧美激情另类亚洲| 亚洲理论片在线观看| 欧美整片在线观看| 亚洲福利视频在线| 日韩av在线网址| 日产精品久久久一区二区福利| 国产精品露脸av在线| 国产成人精品电影久久久| 51午夜精品视频| 久久777国产线看观看精品| 久久精视频免费在线久久完整在线看| 亚洲mm色国产网站| 国产精品久久9| 日本精品久久中文字幕佐佐木| 欧美中文字幕在线视频| 欧美性猛交xxxxx免费看| 欧美日韩在线另类| 中文字幕日韩高清| 欧美电影《睫毛膏》| 国产亚洲在线播放| 久久精品视频播放| 亚洲一级黄色av| 一本色道久久综合亚洲精品小说| 国产91在线播放九色快色| 曰本色欧美视频在线| 欧美成人午夜免费视在线看片| 亚洲韩国青草视频| 精品国产户外野外| 青青草国产精品一区二区| 国产精品成人一区二区三区吃奶| 国产成人免费91av在线| 午夜精品一区二区三区视频免费看| 啊v视频在线一区二区三区| 久久精品91久久久久久再现| 日韩电影中文字幕av| 国产美女直播视频一区| 这里只有精品视频在线| 国产精品人成电影在线观看| 亚洲欧美中文字幕| 日韩在线视频观看| 欧美日韩第一页| 国产偷亚洲偷欧美偷精品| 国外视频精品毛片| 国产精品99久久久久久www| 最近2019年日本中文免费字幕| 欧美一级成年大片在线观看| 亚洲最新av在线| 日本久久91av| 成人激情视频在线观看| 国产精品jizz在线观看麻豆| 欧美尤物巨大精品爽| 亚洲一区二区三区视频| 成人高h视频在线| 精品久久久久人成| 国产成人极品视频| 色琪琪综合男人的天堂aⅴ视频| 免费91麻豆精品国产自产在线观看| 91av在线免费观看| 欧美国产高跟鞋裸体秀xxxhd| 久久亚洲精品视频| 国产欧美在线观看| 亚洲成人激情图| 在线电影av不卡网址| 亚洲视频在线播放| 日韩一区二区久久久| 欧美午夜激情小视频| 欧美午夜激情视频| 国产精品久久久久久久久久| 欧美日韩国产一中文字不卡| 国产激情视频一区| 51视频国产精品一区二区| 亚洲最大中文字幕| 日韩在线观看免费全| 成人精品网站在线观看| 久久精品99久久香蕉国产色戒| 日韩精品在线观看视频| 亚洲美女精品久久| 欧美日韩国产精品一区二区三区四区| 91在线精品视频| 91精品中国老女人| 亚洲在线观看视频| 国产精品视频一区二区三区四| 亚洲人午夜精品免费| 亚洲欧美综合区自拍另类| 久久免费精品日本久久中文字幕| 久色乳综合思思在线视频| 69久久夜色精品国产69乱青草| 亚洲午夜国产成人av电影男同| 亚洲人成欧美中文字幕| 日韩欧美a级成人黄色| 性色av香蕉一区二区| 亚洲视频国产视频| 国产精品高潮呻吟久久av野狼| 97精品国产97久久久久久春色| 九九热在线精品视频| 欧美富婆性猛交| 亚洲天堂免费在线| 国产精品手机播放| 欧美在线国产精品| 国产人妖伪娘一区91| 精品美女久久久久久免费| 亚洲精品国偷自产在线99热| 欧美俄罗斯乱妇| 日韩中文有码在线视频| 色妞在线综合亚洲欧美| xxxxxxxxx欧美| 久久久久久国产精品美女| 亚洲级视频在线观看免费1级| 亚洲中国色老太| 欧洲午夜精品久久久| 亚洲国产成人久久综合一区| 亚洲视频精品在线| 国产91在线高潮白浆在线观看| 欧美激情高清视频| 成人亚洲欧美一区二区三区| 成人亚洲激情网| 日韩欧美在线一区| 91九色视频在线| 精品无码久久久久久国产| 成人免费福利在线| 一本色道久久综合狠狠躁篇怎么玩| 国产精品一区av| 欧美亚洲成人网| 国外成人在线直播| 亚洲国产一区二区三区在线观看| 亚洲自拍偷拍色图| 92福利视频午夜1000合集在线观看| 国产精品福利无圣光在线一区| 亚洲精品福利视频| 色噜噜国产精品视频一区二区| 亚洲欧美国产一区二区三区| 久久99精品久久久久久琪琪| 亚洲japanese制服美女| 亚洲精品国产精品乱码不99按摩| 91亚洲一区精品| 国产精品视频内| 久久久亚洲国产天美传媒修理工| 国产精品成人国产乱一区| 国产精品久久久久久久久借妻| 亚洲成年网站在线观看|