① 如何實現sql Server 2005快速Web分頁
執行程序後的返回結果如下:
pagenumber
saleid
proct
saledate
saleprice
2
12
pooltable
7/11/1908
0:00
640
2
15
pooltable
8/11/1908
0:00
641
2
18
pooltable
9/11/1908
0:00
658
就如你所看到的,程序執行後將會返回一頁的數據,包含三條記錄,而且返回的是第二頁的數據集。
需要注意的一點
一般來說,有兩種方法完成數據結果的分頁:在資料庫層實現和不在資料庫層實現。可以在客戶端實現分頁,但是這樣做的時候,所有的數據都會返回到客戶端,而且在進行數據分析的時候就決定了頁面數目。在早期版本的sql server中,可以在資料庫層實現分頁,但是需要臨時表和表變數。如果上面的例子沒有使用cte來進行分頁的話,分頁程序就不會那麼簡單。之所以這么簡單就是因為使用了row_number函數的強大功能。
② web開發樹形列表怎麼設置分頁
在page類中新加入path屬性,用以存儲每次轉發的路徑及攜帶參數。
private String path;
新建WEBUtils類,獲取路徑,放在新聲明的url中,簡便頁面中的EL表達式。
public static String getPath(HttpServletRequest request){
String requestURI = request.getRequestURI();//獲取請求路徑
String queryString = request.getQueryString();//獲取請求參數
String url = requestURI+"?"+queryString;
if(url.contains("&pageNo")){
url = url.substring(0, url.indexOf("&pageNo"));
}
return url;
}
在servlet中將WEBUtils中獲取的url放入page中。
page.setPath(url)
在要顯示的頁面寫如下代碼,主要是分類進行判斷。
③ JAVA WEB 分頁
這是我自己寫的,不知道對lz有沒有用
分頁包括3個類Page.java,PageService.java,PageSizeConfig.java
一個介面:PageDAO
一個配置文件:page.xml
下面是源碼:(比較懶,沒有寫注釋)
Page.java
public class Page {
public int pageSize; //頁面大小
private int rowSize;//數據總數
private int pageConut;//頁數
private int page;//當前頁數
public Page(int rowSize,int page,int pageSize)
{
this.rowSize=rowSize;
this.pageSize=pageSize;
pageConut=(rowSize-1)/pageSize+1;
this.page=page;
}
public int getRowSize() {
return rowSize;
}
public void setRowSize(int rowSize) {
this.rowSize = rowSize;
pageConut=(rowSize-1)/pageSize+1;
}
public int getPageConut() {
return pageConut;
}
public void setPageConut(int pageConut) {
this.pageConut = pageConut;
}
public int getPage() {
return page;
}
public void setPage(int page) {
this.page = page;
}
//首頁
public void first()
{
page=1;
}
//末頁
public void last()
{
page=pageConut;
}
//下一頁
public void next()
{
page++;
if(page>pageConut)
{
page=pageConut;
}
}
//上一頁
public void previous()
{
page--;
if(page<1)
{
page=1;
}
}
//轉到第currentPage頁
public void go(int currentPage)
{
page=currentPage;
if(page<1)
{
page=1;
}
if(page>pageConut)
{
page=pageConut;
}
}
/**
* 獲取"下一頁"的可用狀態
* 返回空表示不可用,相反則可用
* @return
*/
public String getNext()
{
if(page<pageConut)
{
return "next";
}
return "";
}
/**
* 獲取"上一頁"的可用狀態
* 返回空表示不可用,相反則可用
* @return
*/
public String getPrevious()
{
if(page>1)
{
return "previous";
}
return "";
}
public int getPageSize() {
return pageSize;
}
}
PageServise.java
public class PageService {
public static void service(HttpServletRequest request,PageDAO ,String session)
{
int pageSize=PageSizeConfig.pageSize(.getClass().getName());
String pageAction=request.getParameter("pageAction");
Page p=(Page)request.getSession().getAttribute(session);
if(p==null)
{
p=new Page(.getRowCount(),1,pageSize);
System.out.println("count="+.getRowCount());
}
else
{
p.setRowSize(.getRowCount());
}
if(pageAction==null)
{
return;
}
if("first".equals(pageAction))
{
p.first();
}
else if ("last".equals(pageAction))
{
p.last();
}
else if("next".equals(pageAction))
{
p.next();
}
else if("previous".equals(pageAction))
{
p.previous();
}
else if("go".equals(pageAction))
{
int currentPage=Integer.parseInt(request.getParameter("currentPage"));
p.go(currentPage);
}
request.getSession().setAttribute(session, p);
int start=(p.getPage()-1)*pageSize;
List list=.getDataList(start, pageSize);
request.setAttribute("list", list);
List<Integer> pageList=new ArrayList<Integer>();
for(int i=1;i<=p.getPageConut();i++)
{
pageList.add(new Integer(i));
}
request.setAttribute("pageList", pageList);
}
}
PageSizeConfig.java
public class PageSizeConfig {
public static final int DEFAULT_PAGE_SIZE=5;
private static Map<String,Integer> map;
static
{
load();
}
private static void load()
{
map=new HashMap<String,Integer>();
try {
InputStream is=Thread.currentThread().getContextClassLoader().getResourceAsStream("com/shop/page/page.xml");
DocumentBuilderFactory factory=DocumentBuilderFactory.newInstance();
DocumentBuilder bulider=factory.newDocumentBuilder();
Document doc=bulider.parse(is);
NodeList nl=doc.getElementsByTagName("size");
for(int i=0;i<nl.getLength();i++)
{
Node node=nl.item(i);
String type=node.getAttributes().item(0).getFirstChild().getNodeValue();
int size=Integer.parseInt(node.getTextContent());
map.put(type, new Integer(size));
}
} catch (Exception e) {
e.printStackTrace();
}
}
public static int pageSize(String className)
{
if(map.containsKey(className))
{
return map.get(className);
}
return DEFAULT_PAGE_SIZE;
}
}
PageDAO.java
package com.shop.page;
import java.util.List;
public interface PageDAO<T> {
int getRowCount();
List<T> getDataList(int start,int pageSize);
}
page.xml
<?xml version="1.0" encoding="UTF-8"?>
<page-config>
<size type="com.shop.page.impl.SearchGoodPageImpl">20</size>
</page-config>
我覺得有點不好的就是每個需要分頁的地方都要創建一個session
如果lz覺得有用,email我:[email protected]
④ 使用SSI技術開發web項目如何實現分頁
分頁中,你的後台肯定能得到第幾頁和每頁顯示的行數,這樣的話,你就能算出來需要查出來的是第幾條的數據,如:你每頁顯示10條記錄,現在想顯示第二頁的數據,則資料庫里只需查出來第10-20的10條數據即可。在調用xml中的查詢方法是,將計算出的這兩個數據(如10,20)作為參數傳進去。
以下是DB2中的分頁查詢語句
select * from (
select row_number() over() as rownum_ , row_.* from (
這里邊寫你查詢的sql語句 如:
select ID AS "id", USER_NAME AS 「userName" , PASS_WORD AS "password"
FROM TAB_NAME WHERE 1=1
AND 下邊寫你拼裝的查詢條件 如:
isNotEmpty prepend="and" property="id">
ID = #id#
isNotEmpty>
可以用order by 排序
取出前20行,這個參數應該是傳入的參數,就是上邊計算的第二個參數
fetch first 20 rows only
row_
)as temp where rownum_ <= 20 and rownum_ > 10 --表示取出的行數范圍
其他資料庫,如mysql、oracle等在row_number的取法中有區別,故導致分頁的語句也會有一定的差異,需要你自己去參考些相關的文檔,此出就不列舉了
希望對你有所幫助。
⑤ javaweb項目的分頁
手寫分頁太麻煩了。建議你前台用寫框架比如ext或者easyui裡面分頁都是現成的。
比如easyui裡面的datagrid傳兩個參數一個page當前是第幾頁,rows每頁顯示多少行,後台那這兩個參數拼分頁sql就行。他自動就給你實現了。如果要手寫的話就用標簽什麼的實現,或者js里價格全局變數記錄這兩個參數
⑥ 如何實現SQL Server 2005快速web分頁
在過去,開發人員通常需要自己編寫程序,使用臨時表格來實現分頁功能,或者將所有的數據結果集返回到客戶端,在客戶端進行分頁操作。從開發人員或者DBA的角度來看,兩種方法都不能令人滿意。 隨著SQL Server的發布,其中的一些排序函數使得開發人員編寫數據分頁程序變得更加簡單和高效。這些新的排序函數提供了統計數據集的數目,對數據集歸類,按照某種標准對數據集排序等功能。在這篇文章中,我將著重介紹新增加的ROW-NUMBER排序函數,它會根據你指定的分類標准將結果數據集進行分類,同時給數據集分配連續的頁面。 一個分頁的實例 首先,需要定義一些數據結構。我們定義一個SalesHistory表格,它包含的數據是我們在網上售出產品的銷售記錄。包括一些常見的銷售信息,例如,所售產品、售出日期、產品售出價格等。下面的腳本就是創建這樣的一個表格:
⑦ javaweb中怎麼實現分頁查詢
目前已知有些框架自帶分頁,比如easyui,要麼你就用過sql手寫分頁,比如mysql的limit a,b等
⑧ Java Web 開發中怎麼進行分頁
實現原理很簡單,就是建立一個Page類,裡面放當前訪問的頁數(這個是從客戶瀏覽器傳到後台的數據,所以你的分頁需要用它來定位記錄的條目)和每一頁顯示的記錄行數。然後通過分頁計算就可以得出下列數據。
(假定你的頁數從1開始)
1、總頁數 = 總記錄數/每頁大小,如果0!=總記錄數%每頁大小,那麼總頁數再+1
2、當前頁數(從瀏覽器傳遞的參數中獲得)
3、表記錄的起始位置=(當前頁數-1)*每頁大小
4、總記錄數(select count(*) from [表名] [where [條件]],從資料庫中查詢得到)
5、每頁大小,可以固定,也可以從頁面傳過來
有了這幾個參數之後,就用sql語句查出對應的記錄就可以了。
mysql資料庫用limit 表記錄的起始位置,每頁大小 語句添加到你的查詢語句最後面
sqlserver資料庫用top語句和not in 來做
oracle資料庫用rownum來做
再給你一段分頁對象代碼,你自己先讀一下
public class Page {
private long totalCount = 0;// 總記錄數
private int pageNumber = 1;// 當前頁號,默認顯示第一頁
private int pageSize = 20; // 每頁大小,默認每頁20條
private int totalPage = 0;// 總頁數,默認為0
private int startRow = 0;// 起始記錄行號,默認為從表頭開始
/**
* 分頁計算方法,由setTotalCount調用
*/
public void pagination() {
// 計算總頁數
if (this.totalCount % pageSize == 0)
this.totalPage = new Long(this.totalCount / pageSize).intValue();
else
this.totalPage = new Long(this.totalCount / pageSize).intValue() + 1;
// 排除錯誤頁號
if (this.pageNumber < 1)
this.pageNumber = 1;
if (this.pageNumber > this.totalPage)
this.pageNumber = this.totalPage;
// 計算起始行號
this.startRow = (this.pageNumber - 1) * this.pageSize;
}
public long getTotalCount() {
return totalCount;
}
public void setTotalCount(long totalCount) {
this.totalCount = totalCount;
this.pagination();
}
public int getPageNumber() {
return pageNumber;
}
public void setPageNumber(int pageNumber) {
this.pageNumber = pageNumber;
}
public int getPageSize() {
return pageSize;
}
public void setPageSize(int pageSize) {
this.pageSize = pageSize;
}
public int getTotalPage() {
return totalPage;
}
public void setTotalPage(int totalPage) {
this.totalPage = totalPage;
}
public int getStartRow() {
return startRow;
}
public void setStartRow(int startRow) {
this.startRow = startRow;
}
}
⑨ java web分頁是怎麼回事
得到的數據量過多,需要分頁展示.
MySQL可以利用Limit關鍵字分頁,也可以創建Bean完成分頁。
非常簡單的東西。而且企業是不需要你來做分頁的 早就有人寫好了!
⑩ 求java web高手教會我通過pager-taglib來實現web分頁的作法。我的qq:408545919 不甚感激。
. emp表數據如下
EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO
----- ---------- --------- ----- ----------- --------- --------- ------
7369 SMITH CLERK 7902 1980/12/17 800.00 20
7499 ALLEN SALESMAN 7698 1981/2/20 1600.00 0.00 30
下面代碼輸出的結果是:
...
ResultSet rs = stmt.executeQuery ("select comm from emp");
while(rs.next())
{
System.out.println(rs.getDouble(1) + "," +rs.wasNull());
}
A. 0, true 0, false
B. null, true 0,false
C. 0, false 0, false
D. 0, true 0, true