❶ 問問建網站有經驗的人,你們是怎麼分頁的呢
首先呢, 不建議使用DataGrid自帶的分頁功能
有好些自定義分頁的方法
-----------------
1、利用DataGrid內置的分頁功能
在DataGrid控制項的屬性里加入以下語句
AllowPaging="True"
PageSize="5"
PagerStyle-HorizontalAlign="Right"
註:AllowPaging是指允許分頁。 PageSize是指定每頁顯示的記錄數,如果不寫,就會默認為10條。PagerStyle-HorizontalAlign是指定分頁顯示按鈕的定位,默認是Left。
---------------------
2、利用SQL語句
Select Top @pagesize * from topic where id Not IN (Select Top @pagesize*@pagenum id from topic)
註:@pagesize是指定每頁顯示的記錄數,@pagenum是指第幾頁。
另外topic是表名,id是一個標識列。
-------------------------
3、利用DataSet.Fill
DataSet ds = new DataSet();
SqlDataAdapter MyAdapter = new SqlDataAdapter(strSel,Conn);
MyAdapter.Fill(ds,StartIndex,PageSize,"guest");
Mydatalist.DataSource = ds.Tables["guest"].DefaultView;
註:StartIndex是指讀取第幾條記錄,PageSize是指要讀取多少條記錄
------------------------------
4、利用DataTable.Rows
For i = nStart To nEnd
Response.Write ( DT.Rows ( i ) ( "ItemName" ) & " <br > " )
Next
註:nStart是指開始讀取的記錄的序號,nEnd是指最後讀取的記錄的序號
DT是一個DataTable對象。
--------------------
我是習慣用SQL語句, 它不僅適用於.NET, 同樣適用於ASP等等
❷ 如何實現分頁查詢
方法1:
適用於 SQL Server 2000/2005
SELECT TOP 頁大小 *
FROM table1
WHERE id NOT IN
(
SELECT TOP 頁大小*(頁數-1) id FROM table1 ORDER BY id
)
ORDER BY id
方法2:
適用於 SQL Server 2000/2005
SELECT TOP 頁大小 *
FROM table1
WHERE id >
(
SELECT ISNULL(MAX(id),0)
FROM
(
SELECT TOP 頁大小*(頁數-1) id FROM table1 ORDER BY id
) A
)
ORDER BY id
方法3:
適用於 SQL Server 2005
SELECT TOP 頁大小 *
FROM
(
SELECT ROW_NUMBER() OVER (ORDER BY id) AS RowNumber,* FROM table1
) A
WHERE RowNumber > 頁大小*(頁數-1)
❸ 多條件查詢和分頁
//分頁函數
//定義函數pageft(),三個參數的含義為:
//$totle:信息總數;
//$displaypg:每頁顯示信息數,這里設置為默認是20;
//$url:分頁導航中的鏈接,除了加入不同的查詢信息「page」外的部分都與這個URL相同。
//默認值本該設為本頁URL(即$_SERVER["REQUEST_URI"]),但設置默認值的右邊只能為常量,所以該默認值設為空字元串,在函數內部再設置為本頁URL。
functionpageft($totle,$displaypg=20,$url='',$shownum=1,$showtext=1,$showselect=0,$showlvtao=7){
if(empty($totle)){
returnfalse;
}
$page=isset($_GET['page'])?intval($_GET['page']):1;
$url.='/page/';
//頁碼計算:
$lastpg=ceil($totle/$displaypg);//最後頁,也是總頁數
$page=min($lastpg,$page);
$prepg=$page-1;//上一頁
$nextpg=($page==$lastpg?0:$page+1);//下一頁
$firstcount=($page-1)*$displaypg;
//開始分頁導航條代碼:
if($showtext==1){
$pagenav='<divclass="results"><span>第'.($totle?($firstcount+1):0).'-'.min($firstcount+$displaypg,$totle).'條共'.$totle.'</span></div><div><ulclass="pager">';
}else{
$pagenav="";
}
//如果只有一頁則跳出函數:
//if($lastpg<=1)
//returnfalse;
if($prepg)
$pagenav.='<li><ahref="'.$url.$prepg.'">«上一頁</a></li>';
else
$pagenav.='<liclass="disabled">«上一頁</li>';
if($shownum==1){
$o=$showlvtao;//中間頁碼表總長度,為奇數
$u=ceil($o/2);//根據$o計算單側頁碼寬度$u
$f=$page-$u;//根據當前頁$currentPage和單側寬度$u計算出第一頁的起始數字
//str_replace('{p}',,$fn)//替換格式
if($f<0){
$f=0;
}//當第一頁小於0時,賦值為0
$n=$lastpg;//總頁數,20頁
if($n<1){
$n=1;
}//當總數小於1時,賦值為1
if($page==1){
$pagenav.='<liclass="current">1</li>';
}else{
$pagenav.='<li><ahref="'.$url.'1">1</a></li>';
}
///////////////////////////////////////
for($i=1;$i<=$o;$i++){
if($n<=1){
break;
}//當總頁數為1時
$c=$f+$i;//從第$c開始累加計算
if($i==1&&$c>2){
$pagenav.='<liclass="separator">...</li>';
}
if($c==1){
continue;
}
if($c==$n){
break;
}
if($c==$page){
$pagenav.='<liclass="current">'.$page.'</li>';
}else{
$pagenav.='<li><ahref="'.$url.$c.'">'.$c.'</a></li>';
}
if($i==$o&&$c<$n-1){
$pagenav.='<liclass="separator">...</li>';
}
if($i>$n){
break;
}//當總頁數小於頁碼表長度時
}
if($page==$n&&$n!=1){
$pagenav.='<liclass="current">'.$n.'</li>';
}else{
if($lastpg>1){
$pagenav.='<li><ahref="'.$url.$n.'">'.$n.'</a></li>';
}
}
}
if($nextpg)
$pagenav.='<li><ahref="'.$url.$nextpg.'">下一頁»</a></li>';
else
$pagenav.='<liclass="disabled">下一頁»</li>';
$pagenav.='</ul></div>';
if($showselect==1){
//下拉跳轉列表,循環列出所有頁碼:
$pagenav.="跳至<selectname='topage'size='1'onchange='window.location="$url"+this.value'> ";
for($i=1;$i<=$lastpg;$i++){
if($i==$page)
$pagenav.="<optionvalue='$i'selected>$i</option> ";
else
$pagenav.="<optionvalue='$i'>$i</option> ";
}
$pagenav.="</select>頁";
}
return$pagenav;
}
//數據查詢頁面
$page=array();
$page['url']=U('Supervise/myefficiencybooklist',array('Status'=>$_GET['Status']));
$page['pagesize']=16;
$page['frmnum']=($pagenum-1)*$page['pagesize'];
$Efficiencybook=M('efficiencybook','app_yhcm_supervise_');
$totle=$Efficiencybook->where('uid='.$this->_G['userid'].$where)->count();
$page['totle']=$totle;
$this->assign('page',$page);//將分頁參數復制給模版變數
{:pageft($page['totle'],$page['pagesize'],$page['url'])}
以上是我一個項目裡面用到的 你適當的改下就能用了
❹ 請問如何用jquery 實現html頁面的分頁查詢
首先你需要一個pageBean類,用來定義一些分頁需要的數據!
public class PageBean<T> {
private int pageCount = 0; // 總頁數
private List<T> pageData = null; // 當前頁數據集
private int pageSize = 10; // 每頁大小
private int currentPage = 1; // 當前頁
private long totalRecord = 0; // 總記錄數
private int beginIndex = 0; // 分頁起始記錄號
private int endIndex = 1; // 分頁結束記錄號
public int getPageCount() {
pageCount = (int)(totalRecord + pageSize -1)/pageSize;
return pageCount;
}
public void setPageCount(int pageCount) {
this.pageCount = pageCount;
}
public List<T> getPageData() {
return pageData;
}
public void setPageData(List<T> pageData) {
this.pageData = pageData;
}
public int getPageSize() {
return pageSize;
}
public void setPageSize(int pageSize) {
this.pageSize = pageSize;
}
public int getCurrentPage() {
if (currentPage < 1) {
currentPage = 1;
}
return currentPage;
}
public void setCurrentPage(int currentPage) {
this.currentPage = currentPage;
}
public long getTotalRecord() {
if (totalRecord < 0) {
totalRecord = 0;
}
return totalRecord;
}
public void setTotalRecord(long totalRecord) {
this.totalRecord = totalRecord;
}
public int getBeginIndex() {
beginIndex = (currentPage - 1) * pageSize+1;
return beginIndex;
}
public void setBeginIndex(int beginIndex) {
this.beginIndex = beginIndex;
}
public int getEndIndex() {
endIndex = currentPage * pageSize;
return endIndex;
}
public void setEndIndex(int endIndex) {
this.endIndex = endIndex;
}
}
頁面上,使用jQuery的Ajax發送後台請求信息:
$.ajax({
type:"post",
url:"requestPage",
dataType:"json",
data:{這里就是封裝數據的地方,比如你要到第二頁的時候,在這之前要讀取當前的頁數,並進行適當的判斷,是鍵值對的形式例如:"current":1,"pageSize":10},
success:function(data){
這里是返回json字元串
var jsonObj=$(data);
然後解析遍歷json
$.each(data.pageData,function(index,item){
這個回調函數裡面的第一個參數是下標,第二個參數是集合裡面的單個對象
然後生成顯示…………結束
});
}
}):
❺ 怎麼進行分頁數據的查詢,如何判斷是否有下一頁
jsp中分頁顯示查詢到的數據是通過foreach標簽控制的,一般是顯示首頁,下一頁,上一頁,尾頁這些連接項。
1、構建一個PageControl對象將分頁所涉及到的一些關鍵的"控制數據"予以封裝.
❻ 怎樣實現資料庫的分頁查詢
針對查詢語句做處理,同時對請求頁面地址做分析
list.aspx?pageid=5 //表示訪問第五頁
後台語言里,先對查詢條件做預處理
pagepre=pagesize*4 //pagesize 用於表示分頁大小,例如10,則前4頁共有40條記錄
查詢語句
sqlcmd="select top "+pagesize+" from tabelname where id not in (select top "+pagepre+" from tablename order by id desc)"
操作原理為將當前頁前顯示的所有記錄從數據查詢結果中排除,也就是not in 後面的部分,然後從剩餘的結果沖,讀取pagesize大小的記錄值。篩選條件、排序條件放在子查詢中
❼ 怎樣實現jsp顯示分頁 例如:查詢新聞信息時分頁顯示
jsp分頁方式有,真分頁和假分頁。
假分頁,將需要展示的數據從資料庫一次全部查出,然後在伺服器端、或者前台分頁。
真分頁,只將本頁展示的數據從資料庫中查出,然後顯示在前台。
假分頁,很少適用。一般的系統都採用真分頁。
真分頁需要資料庫的支持。
MySQL 資料庫
select * from Table limit startrow perpagesize
Oracle資料庫
Select * from
(
select a.*, rownum rc
from
(select * FROM Table order by Table_id asc) a where rownum <=endrow
) b where rc >=startrow
DB2資料庫
select * from ( select rownumer() over() as rc, a.*
from (select * from Table order by Table_id asc) ) as a ) where rc between startrow and endrow
❽ 在同一頁面中如何實現查詢並分頁顯示結果
建立access的資料庫news,還有表news,表的欄位(id,title),id唯一,輸入數據保存,用下面代碼可查詢,可分頁
-----------------------下面保存為search.asp--------------------------
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<title>文件</title>
</head>
<body bgcolor="#ffffff">
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<script>
function btn_ck_bh_Click()
{
var cx = document.form1.cxsj.value;
form1.action ="search.asp?cx="+cx;
}
</script>
<table border="1" cellspacing="0" bgcolor="#F0F8FF" bordercolorlight="#4DA6FF" bordercolordark="#ECF5FF" width="88%" style="word-break:break-all">
<tr>
<td width="778" align="center" colspan="7">
<form method="POST" name="form1" action=search.asp>
<p>輸入搜索內容:<input type="text" name="cxsj" size="20"><input type="submit" value="提交" name="B1" LANGUAGE="javascript" onclick="btn_ck_bh_Click()">
<input type="reset" value="重寫" name="B2"></p>
</form>
</td>
</tr>
</table>
<table border="1" cellspacing="0" bgcolor="#F0F8FF" bordercolorlight="#4DA6FF" bordercolordark="#ECF5FF" width="88%" style="word-break:break-all">
<tr>
<td width="8%" align="center"><strong><font color="#0080C0">ID 號</font></strong></td>
<td width="58%" align="center"><strong><font color="#0080C0">標 題</font></strong></td>
<td width="8%" align="center"><strong><font color="#0080C0">修 改</font></strong></td>
<td width="8%" align="center"><strong><font color="#0080C0">刪 除</font></strong></td>
</tr>
<%
'資料庫查詢
'獲得搜索內容
cx = request("cx")
dim pageCount
'把page轉換成整數
page = cint(request("page"))
set conn=server.createobject("adodb.connection")'
set rs=server.createobject("adodb.recordset")
conn.open "DBQ=" & server.mappath("./news.mdb") & ";DefaultDir=;DRIVER={Microsoft Access Driver (*.mdb)};"
' 獲取產品的名字記錄集(從 news表中)
if cx <> "" then
sql = "select * from news where title like '%"&cx& "%' order by id desc"
else
sql ="select * from news order by id desc"
end if
rs.open sql,conn,3,3
'如果沒有數據記錄
if rs.bof then
errmsg=errmsg+"<br>"+"<li>"+keyword+"沒有記錄,請返回!!"
response.write errmsg
response.end
end if
' 設置記錄集在每頁的總行數,也就是 PageSize屬性
RS.PageSize=40
'把rs.pageCount轉換成整數和page才能作比較
pageCount = cint(rs.pageCount)
' 設置當前的頁號( AbsolutePage屬性)
if page = 0 then
page =1
end if
RS.AbsolutePage = page
x=1
' 顯示當前頁中的所有記錄( PageSize中設置的行數)
WHILE NOT RS.EOF AND NumRows<RS.PageSize
%>
<tr onmouseover="this.bgColor='#99ccff'" onmouseout="this.bgColor=''">
<td width="8%"><p align="center"><%=rs("id")%></td>
<td width="58%"><a href="view.asp?id=<%=rs("id")%>" target="_blank"><%=rs("title")%></a></td>
<td width="8%" align="center"><a href="edit.asp?id="<%=rs("id")%>>修 改</a></td>
<td width="8%" align="center"><a href="delet.asp?id="<%=rs("id")%>>刪 除</a></td>
</tr>
<%RS.MoveNext
NumRows=NumRows+1
WEND%>
<tr onmouseover="this.bgColor='#99ccff'" onmouseout="this.bgColor=''">
<td width="105%" align="center" colspan="6"> </td> </tr>
<tr>
<td width="105%" align="center" colspan="6">
<p align="center"><FONT color=#333333>共<%=PageCount%>頁 第<%=page%>頁★
<%if page=1 then%>首頁<%end if%>
<%if page>1 then%>
<A HREF="search.asp?page=1&cx=<%=cx%>"> 首頁</A>
<%end if%>★
<%if page>1 then%><A HREF="search.asp?page=<%=page-1%>&cx=<%=cx%>"><%end if%>上一頁</a>
<%
dim pagewhere
dim p
p = 1
'把pagewhere轉換成整數
'pagewhere = cint(request("pagewhere"))
pagewhere = pageCount
if pagewhere>0 then
for p=1 to pagewhere
if p <> page then%>
<A HREF="search.asp?page=<%=p%>&cx=<%=cx%>"><%=p%></a>
<%end if
if p =page then%>
<%=p%>
<% end if
next
end if%>
<%if page < PageCount then%>
<A HREF="search.asp?page=<%=page+1%>&cx=<%=cx%>">
<%end if %>下一頁</A>★
<%if page=PageCount then%>尾頁
<%end if%>
<%if page<PageCount then%>
<A HREF="search.asp?page=<%=PageCount%>&cx=<%=cx%>"> 尾頁</A>
<%end if%>
</p></FONT></td> </tr> <tr>
<td width="105%" align="center" colspan="6">搜索內容:<%=cx%></td>
</tr>
</table></center></div>
</body></html>
<%
rs.close
Set rs=nothing
conn.close
set conn=nothing
%>
❾ 什麼叫「分頁查詢」
分頁查詢,是一種操作系統里存儲器管理的一種技術,可以使電腦的主存可以使用存儲在輔助存儲器中的數據。操作系統會將輔助存儲器(通常是磁碟)中的數據分區成固定大小的區塊,稱為「頁」(pages)。當不需要時,將分頁由主存(通常是內存)移到輔助存儲器;當需要時,再將數據取回,載入主存中。相對於分段,分頁允許存儲器存儲於不連續的區塊以維持文件系統的整齊。分頁是磁碟和內存間傳輸數據塊的最小單位。
(9)分頁怎麼查詢網站招聘擴展閱讀:
分頁查詢的頁面調度類型
1、當需要用到數據時再向系統請求,使系統將數據由輔助存儲器傳入存儲器上,這就叫「需求分頁」。它使得系統不需要將全部的程序都放在存儲器上,減少了所需要的存儲器的數量。所有現代系統都使用按需頁面調度(paging)的方式。
2、當系統查看分頁表時認為某些數據可能需要用到,而先將數據傳到存儲器上的行為,就叫做「先行分頁」, 當存儲器夠大的話通常會採取這種方式。
3、Unix系統會定期使用sync程序來清理所有經過更動的幀,它會將所有被更動過的幀存到輔助存儲器中。Windows系統有時亦會進行類似功能的操作,它可以使新程序在打開時更快速。
❿ 如何查看中科院各分所招收理學還是農學研究生
你可以直接去報考專業的院 (所)網站上看招生分頁看簡章和專業 不同的代碼表示不同的 工學,理學 專業型 學術型等