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

首頁 > 數據庫 > Oracle > 正文

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

2020-07-26 14:04:26
字體:
來源:轉載
供稿:網友

就如平時我們很在分頁中看到的,分頁的時候返回的不僅包括查詢的結果集(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分頁功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對武林網網站的支持!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产98色在线| 国产欧美日韩综合精品| 日韩免费精品视频| 国产欧美婷婷中文| 国产欧洲精品视频| 亚洲精品久久久久久久久久久久| 尤物精品国产第一福利三区| 青青a在线精品免费观看| 欧美日韩国产999| 91国内精品久久| 国产精品第10页| 日韩在线不卡视频| 成人做爽爽免费视频| 欧美激情国产高清| 亚洲精品日韩欧美| 色偷偷888欧美精品久久久| www.xxxx精品| 久久久精品久久| 一区二区三区视频免费| 日本三级韩国三级久久| 国产午夜精品久久久| 91亚洲精品在线| 欧美孕妇孕交黑巨大网站| 九九热r在线视频精品| 色综合色综合久久综合频道88| 92国产精品久久久久首页| 久久精品99国产精品酒店日本| 精品国产一区二区在线| 国产精品欧美日韩一区二区| 国产精国产精品| 久久精品国产2020观看福利| 久久精品国产成人| 亚洲第一精品福利| 国产精品av在线播放| 久久久91精品国产一区不卡| 日韩在线免费视频观看| 亚洲福利视频网| 2019中文字幕免费视频| 国产中文字幕日韩| 欧美大人香蕉在线| 欧美激情精品在线| 日韩精品中文字幕视频在线| 久久不射热爱视频精品| 国产精品久久久久久久久借妻| 亚洲自拍偷拍视频| 久久久人成影片一区二区三区观看| 久久在精品线影院精品国产| 亚洲xxx视频| 中文字幕国产亚洲| 国产精品99久久99久久久二8| 国产亚洲精品久久久| 在线日韩精品视频| 国产午夜精品全部视频播放| 久久久久久亚洲精品不卡| 国产97人人超碰caoprom| 国产日韩精品在线播放| 亚洲欧美日韩第一区| 亚洲欧洲激情在线| 久久久久一本一区二区青青蜜月| 在线亚洲男人天堂| 亚洲最大的成人网| 亚洲性夜色噜噜噜7777| 欧美xxxx综合视频| 亚洲国产成人久久综合一区| 欧美极品少妇xxxxⅹ免费视频| 欧美日韩国产综合新一区| 91精品综合久久久久久五月天| 久久人人爽人人爽人人片av高清| 在线精品视频视频中文字幕| 日韩中文字幕在线视频播放| 久久久亚洲精品视频| 欧美成人黄色小视频| 欧美精品手机在线| 国产精品精品一区二区三区午夜版| 日韩av在线精品| 亚洲国产成人在线播放| 在线观看日韩www视频免费| 成人精品视频久久久久| 国产精品自拍偷拍视频| 亚洲人成绝费网站色www| 91情侣偷在线精品国产| 成人日韩在线电影| 欧美精品免费在线观看| 亚洲国产91精品在线观看| 欧美黄色片视频| 日韩有码在线电影| 91九色国产社区在线观看| 伊人亚洲福利一区二区三区| 中文日韩在线观看| 久久久久中文字幕| 亚洲美女av网站| 视频在线一区二区| 在线观看亚洲区| 欧美人与性动交a欧美精品| 色噜噜狠狠狠综合曰曰曰88av| 国产亚洲精品久久久久动| 国产欧美日韩专区发布| 亚洲高清久久网| 51视频国产精品一区二区| 亚洲精品视频免费在线观看| 亚洲精品网站在线播放gif| 欧美精品国产精品日韩精品| 亚洲国产一区二区三区在线观看| 91在线免费看网站| 91国语精品自产拍在线观看性色| 欧美在线国产精品| 色偷偷88888欧美精品久久久| 欧美另类老肥妇| 国产一区二区三区视频免费| 高潮白浆女日韩av免费看| 日本午夜精品理论片a级appf发布| 情事1991在线| 国产精品男人的天堂| 欧美高清无遮挡| 国产精品日韩一区| 久久精品2019中文字幕| 91久久综合亚洲鲁鲁五月天| 亚洲福利在线视频| 日韩一区视频在线| 日韩精品免费在线观看| 国产成人jvid在线播放| 国产精品第一区| 欧美精品第一页在线播放| 国产精品99蜜臀久久不卡二区| www.国产一区| 91免费精品视频| 欧洲美女7788成人免费视频| 欧美午夜片欧美片在线观看| 一区二区三区无码高清视频| 成人黄色免费片| 日韩成人在线视频| 国产精品久久综合av爱欲tv| 国模精品一区二区三区色天香| 欧美情侣性视频| 亚洲欧美制服第一页| 亚洲欧洲一区二区三区在线观看| 亚洲视频在线免费看| 国产精品成人播放| 久久全球大尺度高清视频| 91国产视频在线| 亚洲电影av在线| 国产精品亚洲美女av网站| 亚洲天堂av女优| 亚洲女人天堂成人av在线| 久久伊人精品一区二区三区| 欧美精品国产精品日韩精品| 久久视频中文字幕| 91av在线精品| 亚洲国产美女精品久久久久∴| 国产女同一区二区| 成人羞羞国产免费| 91在线免费看网站| 一区二区在线视频播放| 在线日韩精品视频| 色悠久久久久综合先锋影音下载| 日韩精品中文字幕视频在线| 亚洲精品国产精品国自产观看浪潮| 精品久久久久久久久久久久久| 欧美激情免费在线| 在线观看亚洲视频| 欧美激情视频网站| 国产精品久久婷婷六月丁香| 亚洲成人三级在线| 精品久久久久久亚洲国产300|