簡體   English   中英

如何提高分頁速度

[英]How to increase the pagination speed

在我的項目中,我使用PHP進行了分頁,如下所示:每個按鈕(“下一頁”和“上一頁”)都是超鏈接,通過傳遞GET變量(PAGENUMBER)鏈接到同一頁面。 對於每個頁面更改,都有用於

  1. 連接到DB。
  2. 查詢指定頁面的數據。
  3. 關上
  4. 數據庫連接。 顯示數據。

問題是它運行緩慢。 每次連接到db並查詢數據並關閉db連接時,是否有任何其他方法。

另外在分頁過程中,我只想從數據庫中重新加載數據,頁面中的所有其他內容保持不變,並且不想重新加載。 如何實現呢?

腳本如下

    <?php
require_once("./include/membersite_config.php");    //include files for login system
if($fgmembersite->CheckLogin())
{
    $login=true;
}
else
{
    $login=false;
}
require_once("db.php"); 
$con=connect();     //connect to db and select the db
?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<HTML>
    <HEAD>
        <TITLE> Gallery </TITLE>
        <META name="generator" content="Adobe Photoshop(R) CS Web Photo Gallery">
        <META http-equiv="Content-Type" content="text/html; charset=iso-8859-1">
        <link href="images/galleryStyle.css" rel="stylesheet" type="text/css">
         <link rel="STYLESHEET" type="text/css" href="style/new.css" />
    </HEAD>
<body  marginheight=0 marginwidth=0 leftmargin=0 topmargin=0>
<table><tr>
<?php
//////////////////DISPLAYING IMAGE THUNBNAILS//////////////////////
$query="SELECT COUNT(*) FROM gallery ";
$res = query($query);
$raw=mysql_fetch_array($res);
$imagecount=$raw[0];
if($imagecount==0) { die ("No images found"); }
$pagecount=ceil($imagecount/15); 
$page = isset($_GET['page']) ? mysql_real_escape_string($_GET['page']) : 1;
if (isset($_GET['page']))
{
   if (!(ctype_digit($_GET['page']) and $_GET['page']>0 and $_GET['page']<=$pagecount))
   { 
       die ("You are not autorised to viw this page");
   }
}
$start= ($page*15)-15; 
$query = "SELECT * FROM gallery  ORDER BY imageid DESC LIMIT $start , 15";
$res = query($query);
$count= mysql_num_rows($res);
$index=0;
for($i=1;$i<=3;$i++)
{
?>
<TR>
<?php
for($j=1;$j<=5;$j++)
{
   if(!$raw=mysql_fetch_array($res)) {break;}
   $index++;
   $imageid=$raw['imageid'];
   $thumbpath= $raw['thumbpath'];
   $largepath=$raw['largepath'];
   $caption=$raw['caption'];
?>
<A name=1 href="image.php?imageid=<?php echo $imageid ?>&imageindex=<?php echo ((($page-1)*15)+$index-1) ;  ?> "><IMG  border=0 src="<?php echo $thumbpath; ?>" height="75" width="75" alt="<?php echo $caption ?>" title="<?php echo $caption ?>" ></A><BR>
<?php
echo "<a href='delete.php?delete=yes&imageid=".$imageid.'&page='.$page."'>Delete </a>"
echo "<a href='replace.php?update=yes&imageid=".$imageid.'&page='.$page."'>Replace </a>"
?>
</table>
</td>
<?php } ?>
</TR>
<?php
} 
if ($page!=1)
{
?>
<td width=17><a href=" <?php echo $_SERVER['PHP_SELF'].'?page='.($page-1); ?> "><IMG SRC="images/previous.gif" BORDER=0></a></td>
<?php  } ?>
<td align=middle class="pagenums"><?php echo "page ".$page." of ".$pagecount ?></td>
<?php
if ($page!=$pagecount)
{
?>
<td align=right width=17><a href=" <?php echo $_SERVER['PHP_SELF'].'?page='.($page+1); ?> "><img border=0 src="images/next.gif"></a></td>
<?php } ?>
</table>
</body>
</html>

有很多選擇

  1. 使用javascript分頁
  2. 阿賈克斯分頁
  3. 嘗試減少分頁代碼(優化代碼)

您無需為每個頁面更改連接/關閉數據庫

使用ajax腳本通過重新加載當前頁面來連接和獲取數據庫值就可以做到-------試試ajax

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM