當前位置:首頁 » 操作系統 » java資料庫分頁

java資料庫分頁

發布時間: 2023-07-07 00:09:53

A. java查詢的分頁思路!!

分頁顯示一般有兩種實現方式:業務層分頁、資料庫層分頁(以下會用到兩個參數,提前說明下 page:請求第幾頁,size:每頁顯示多少條)

業務層分頁:從資料庫取出所有數據,然後通過傳過來的page和size對所有數據截取,比如一共查了100條數據,保存在list裡面,要求查詢第2頁,每頁顯示10條,則可以通過list屬性,取100條數據 中的第11條到第20條,可通過遍歷實現。

資料庫層分頁:資料庫都會有分頁函數(mysql 是limit函數,sqlServer是row_number()函數,可自行網路下)該方法是通過傳過來的page和size在查詢資料庫時就開始分頁,以mysql為例,查詢第2頁,每頁顯示10條,則sql語句是 」select * from XX limit 10,10「(第一個10表示從下標為10開始查,第二個10是共讀取10條)

性能肯定是第二種分頁方式好,只要搞懂分頁原理,想實現分頁其實很簡單,只要搞清楚分頁是將多條數據中的某幾條挑出來

B. 怎樣用java實現分頁顯示,該怎麼解決

在項目中,分頁是一個項目中必不可少的,它可以防止我們從資料庫中進行大量數據查詢時速度變慢,提高我們的查詢效率
1、定義分頁模型:PageModel
package com.common.page;

import java.util.List;

/**
* 封裝分頁信息
* @author Administrator
*
*/
public class PageModel<E> {

//結果集
private List<E> list;

//查詢記錄數
private int totalRecords;

//每頁多少條數據
private int pageSize;

//第幾頁
private int pageNo;

/**
* 總頁數
* @return
*/
public int getTotalPages() {
return (totalRecords + pageSize - 1) / pageSize;
}

/**
* 取得首頁
* @return
*/
public int getTopPageNo() {
return 1;
}

/**
* 上一頁
* @return
*/
public int getPreviousPageNo() {
if (pageNo <= 1) {
return 1;
}
return pageNo - 1;
}

/**
* 下一頁
* @return
*/
public int getNextPageNo() {
if (pageNo >= getBottomPageNo()) {
return getBottomPageNo();
}
return pageNo + 1;
}

/**
* 取得尾頁
* @return
*/
public int getBottomPageNo() {
return getTotalPages();
}

public List<E> getList() {
return list;
}

public void setList(List<E> list) {
this.list = list;
}

public int getTotalRecords() {
return totalRecords;
}

public void setTotalRecords(int totalRecords) {
this.totalRecords = totalRecords;
}

public int getPageSize() {
return pageSize;
}

public void setPageSize(int pageSize) {
this.pageSize = pageSize;
}

public int getPageNo() {
return pageNo;
}

public void setPageNo(int pageNo) {
this.pageNo = pageNo;
}
}
2、分頁測試:在MySQL中建立admin表,裡面有欄位id、name、password

3、簡歷Admin的實體bean類:
package com.common.page;

public class Admin {
private int id;
private String name;
private String password;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}

}

4、測試調用: package com.common.page;

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 com.common.db.DbUtil;

public class Client {
public static PageModel findAdmins(int pageNo,int pageSize){
Connection conn=DbUtil.getConnection();
String sql="select * from admin limit ?,?";
PageModel pageModel=null;
PreparedStatement pstm=null;
ResultSet rs=null;
Admin admin=null;
List<Admin> list=new ArrayList<Admin>();
try {
pstm=conn.prepareStatement(sql);
pstm.setInt(1, (pageNo-1)*pageSize);
pstm.setInt(2, pageNo*pageSize);
rs=pstm.executeQuery();;
while(rs.next()){
admin=new Admin();
admin.setId(rs.getInt("a_id"));
admin.setName(rs.getString("a_name"));
admin.setPassword(rs.getString("a_pwd"));
list.add(admin);
}
ResultSet rs2=pstm.executeQuery("select count(*) from admin");
int total=0;
if(rs2.next()){
total=rs2.getInt(1);
}
pageModel=new PageModel();
pageModel.setPageNo(pageNo);
pageModel.setPageSize(pageSize);
pageModel.setTotalRecords(total);
pageModel.setList(list);
} catch (SQLException e) {
e.printStackTrace();
}finally{
DbUtil.close(conn);
DbUtil.close(pstm);
DbUtil.close(rs);
}
return pageModel;
}

public static void main(String[] args) {
PageModel pageModel=Client.findAdmins(2,4);
List<Admin> list=pageModel.getList();
for(Admin a:list){
System.out.print("ID:"+a.getId()+",用戶名:"+a.getName()+",密碼:"+a.getPassword());
System.out.println();
}
System.out.print("當前頁:"+pageModel.getPageNo()+" ");
System.out.print("共"+pageModel.getTotalPages()+"頁 ");
System.out.print("首頁:"+pageModel.getTopPageNo()+" ");
System.out.print("上一頁:"+pageModel.getPreviousPageNo()+" ");
System.out.print("下一頁:"+pageModel.getNextPageNo()+" ");
System.out.print("尾頁:"+pageModel.getBottomPageNo()+" ");
System.out.print("共"+pageModel.getTotalRecords()+"條記錄");
System.out.println();
}

}
這樣分頁效果就實現了,我們要實現分頁效果,只要傳入相應的參數和相應的資料庫執行語句即可實現,希望大家能靈活運用。

C. java中資料庫中實現分頁的sql語句要求每頁十條要查詢的是第二頁

1、首先preparedstatement是statement的子介面,屬於預處理操作,與直接使用statement不同的是,preparedstatement在操作的時候,先在數據表中准備好了一條sql語句,但是sql語句的值暫時不設置,而是之後設置。

D. 怎樣用java實現分頁顯示

實現原理很簡單,就是建立一個Page類,裡面放當前訪問的頁數碼遲和每一頁顯示的記錄行數。然後通過分頁計算就可以得出下列數據。

  1. 總頁數 = 總記錄數/每頁大小陪敬,如果0!=總記錄數%每頁大小,那麼總頁數再+1。

  2. 當前頁數。

  3. 表記錄的起始位置=(當前頁數-1)*每頁大小。

  4. 總記錄數(select count(*) from [表名] [where [條件]]。從資料庫中查詢得到)

  5. 每頁大小,可以固定,也可以從頁面傳過來有了這幾個參數之後,就用sql語句查出對應的記錄就可以了。

E. java分頁

分頁想清楚了就沒什麼難的了。一般有兩種(我就知道兩種):

1.資料庫分頁:
/**
* @param pageItems:一頁顯示條數 currentPage:當前第幾頁
* @autor godelegant
*/
public List findAll(int pageItems,int currentPage){
StringBuffer sqlStr = new StringBuffer("select * from Proct limit ?,?");
...
...
int startIndex = (currentPage-1)*pageItems;);//(currentPage-1)*pageItems能過當前頁和頁面記錄數得到應該從哪條開始取
int endIndex = startIndex+pageItems;
db.getPstmt().setInt(1,startIndex);
db.getPstmt().setInt(2,endIndex);
ResultSet rs = db.getPstmt().executQuery();//假設你已經得到了資料庫連接

//以上為MYSQL的JDBC分頁,下面是ORALCE的,差別只在於SQL,所以你換一下SQL就OK:
StringBuffer sqlStr = new StringBuffer("select *,rownum rn from (select * from Proct) where rn <=? and rownum >=?");

}
求總頁數的方法很簡單,查出所有記錄數,除一頁顯示數。就可以得到

以上是JDBC的,如果使用hibernate等,資料庫分頁將會變得很簡單,只需要設置兩個參數,就是從哪取和取多少。

2.代碼分頁
思路是將資料庫中的所有記錄都取出來,然後再分頁。
/**
* @para items:資料庫中的所有記錄,你可以使用另一個方法得到,如何查詢得到我就不用說了吧
* @autor godelegant
*/
public List findAll(List items,int pageItems,int currentPage){
int startIndex = (currentPage-1)*pageItems;//從哪裡開始取
int offset = items.size()-startIndex;//還有多少沒有取過

int pageCount = offset>pageItems?pageItems:offset;//如果沒有取過的大於需要顯示的數,則實現顯示數pageCount=pageItems,反之然;

List<Proct> pageList = new ArrayList();
for(int i=startIndex,i<startIndex+pageCount,i++){
pageList.add(items.get(i));
}

return pageList;

}

寫了40分鍾,希望對你有用

熱點內容
可以上傳視頻網站 發布:2025-03-18 01:29:17 瀏覽:931
mysql密碼忘記了怎麼 發布:2025-03-18 01:23:00 瀏覽:857
java與oracle 發布:2025-03-18 01:18:05 瀏覽:704
怎麼給win7電腦文件加密 發布:2025-03-18 01:10:41 瀏覽:988
python生成隨機數 發布:2025-03-18 01:10:40 瀏覽:94
手機存儲卡怎麼設置 發布:2025-03-18 01:04:26 瀏覽:213
背演算法好處 發布:2025-03-18 01:02:18 瀏覽:57
win7添加刪除在哪個文件夾 發布:2025-03-18 01:02:13 瀏覽:705
蘋果寫源碼 發布:2025-03-18 00:50:47 瀏覽:363
生存源碼 發布:2025-03-18 00:50:46 瀏覽:351