class wind_page
{
var $page;
//现在所在页
var $total;
//记录总条数
var $totalpage;
//总页树
var $pagesize;
//每页显示条数
var $offset;
//偏移量
var $result;
//记录集合
var $thispage;
//记录总条数 //记录总条数 //记录总条数
var $link;
//连接(记录$_get变量)
var $bar_mun;
//bar显示的页数
var $starttime;
//开始时间
var $bar_last;
//导航条的持续页数
var $bar_mid;
//导航条中间页
var $minpage;
//导航条最小页
var $maxpage;
//导航条最大页
var $key;
//标识分页(一个页面多个分页时用与区分)
var $style;
//输出的风格
var $pre_page_char;
//上一页
var $pre_page_image;
//上一页图形
var $pre_page_char_color;
//上一页字体颜色
var $next_page_char;
//下一页
var $next_page_image;
//下一页图形
var $next_page_char_color;
//下一页字体颜色
var $pre_groud_char;
//上翻中间页数
var $pre_groud_char_color;
//上翻中间页数字体颜色
var $next_groud_char;
//下翻中间页数
var $next_groud_char_color;
//下翻中间页数字体颜色
var $first_page_char;
//首页
var $first_page_char_color;
//首页字体颜色
var $last_page_char;
//尾页
var $last_page_char_color;
//尾页字体颜色
var $html_page_val;
//html当前的页码值
function wind_page($sql, $pagesize = 20, $bar_mun = 10, $style = 1,$this_page = 1,$html_page_val=1,$key = "") //构造函数()
{
$this->starttime = microtime();
$this->pagesize = $pagesize;
//每页显示条数
$this->key = trim($key);
$this->bar_mun = $bar_mun;
$this->style = $style;
$this->html_page_val = $html_page_val;
//html当前的页码值
$this->bar_last = $bar_mun-1;
$this->bar_mid = floor($bar_mun/2);
$this->sql = $sql;
$result = mysql教程_query($this->sql);
$this->total = mysql_num_rows($result);
//记录总条数
$this->totalpage = ceil($this->total/$this->pagesize);
//总页数
//$this->page = ceil($_get[$this->key."page"]);
$this->page = $this_page;
//现在所在页
if ($this->page == "" || $this->page < 1 || !is_numeric($this->page))$this->page = 1;
$this->page = min($this->page, $this->totalpage);
$this->thispage = $this->pagesize;
if ($this->page * $this->pagesize > $this->total) {
$this->thispage = $this->total-($this->page-1) * $this->pagesize;
};
$this->sql .= " limit ".($this->pagesize * ($this->page-1)).", ".$this->pagesize;
//开始读取的条数
//echo "<br>";
$this->result = mysql_query($this->sql);
$this->getvar();
$this->pre_page_char = "上一页";
$this->pre_page_image = "<img src="/images/b_s_prev.gif" border="0" />";
$this->next_page_char = "下一页";
$this->next_page_image = "<img src="/images/b_s_next.gif" border="0" />";
$this->pre_groud_char = "上一组";
$this->next_groud_char = "下一组";}
function getvar() //取得除page外的其他get变量
{
$this->link = "";
foreach($_get as $key => $vaule) {
if (strtolower($key) !== $this->key."page") $this->link .= "&$key=$vaule";
}
}
function pre_page($color="#909090",$sign=0) //上一页
{
if ($this->page > 1) {
return "<a href="index_".sprintf("%02d",$this->page-1).".html" class="ab"><font color="".$this->pre_page_char_color."">".$this->pre_page_char."</font></a>";
} else
{
return "<font color="$color">".$this->pre_page_char."</font>";
}
}
function next_page($color="#909090",$sign=0) //下一页
{
if ($this->page < $this->totalpage) {
return "<a href="index_".sprintf("%02d",$this->page+1).".html" class="ab">".$this->next_page_char."</a>";
} else {
return "<font color="$color">".$this->next_page_char."</font>";
}
}
function pre_groud($char = "<<", $color = "#909090") //上一组
{
if ($this->page <= ($this->bar_mid+1)) {
return "<font color="".$color."">".$this->pre_groud_char."</font>";
//return $this->pre_groud_char;
} else {
$pre_gpage = ($this->page-$this->bar_mid < 0)?1:
$this->page-$this->bar_mid;
return "<a href="index_".sprintf("%02d",$pre_gpage).".html" title="上一组">".$this->pre_groud_char."</a>";
}
}
function next_groud($char = ">>", $color = "#909090") //下一组
{
if (($this->totalpage-$this->page) <= ($this->bar_mid-1)) {
return "<font color="".$color."">".$this->next_groud_char."</font>";
} else {
$next_gpage = ($this->page+$this->bar_mid < $this->totalpage)?$this->page+$this->bar_mid:
$this->totalpage;
return "<a href="index_".sprintf("%02d",$next_gpage).".html" title="下一组" >".$this->next_groud_char."</a>";
}
}
function mun($lcolor = "#ff6633", $acolor = "#ff6633", $left = " ", $right = " ") //数字导航栏
{
$link = "";
$this->minpage = ($this->page-$this->bar_mid < 1) ? 1:($this->page-$this->bar_mid);
$this->maxpage = $this->minpage+$this->bar_last;
if ($this->maxpage > $this->totalpage) {
$this->maxpage = $this->totalpage;
$this->minpage = ($this->maxpage-$this->bar_last < 1) ? 1: $this->maxpage-$this->bar_last;
}
for($i = $this->minpage; $i <= $this->maxpage; $i++)
{
/* 循环输出页码 */
$i = sprintf("%02d",$i);
//不足两位的前面补0
$char = $left.$i.$right;
//导航条左右两边加窄
if ($i == $this->page)
{
/* 假如是当前页则不加链接 */
$link.= "<font color="".$acolor."">".$char."</font>";
}
else
{
//$link .= "<a href="".$_server['php教程_self']."?".$this->key."page=".$i.$this->link."" >".$char."</a>";
$link.= "<a href="index_".$i.".html" >".$char."</a>";
//关键把$link 加在新资料加入之后
}
}
echo "<br>";
return $link;
}
function jump_bar($class = "jump_bar") //下拉跳转
{
$link = "<select name="menu1" onchange="mm_jumpmenu('parent',this,0)" class="$class">";
for($i = $this->minpage; $i <= $this->maxpage; $i++) {
if ($i < 10)$i = "0".$i;
//定义选择不超过10个
if($this->page == $i)
{
/* 假如为当前页码,则选中 */
$link .= "<option value="index_".$i.".html" selected>第".$i."页</option>";
}
else
{
$link .= "<option value="index_".$i.".html">第".$i."页</option>";
}
}
$link .= "</select>";
return $link;
}
function mun_bar() //整条数字导航栏 [<<][<][01][02][03][04][05][06][07][08][09][10][>][>>]
{
//return $this->first_groud().$this->pre_groud().$this->pre_page().$this->mun().$this->next_page().$this->next_groud().$this->last_groud();
return $this->pre_groud()." ".$this->pre_page().$this->mun().$this->next_page()." ".$this->next_groud();
}
function page_button()
{ //整条数字导航栏 [<][01][02][03][04][05][06][07][08][09][10][>]
//return $this->first_groud().$this->pre_groud().$this->pre_page().$this->mun().$this->next_page().$this->next_groud().$this->last_groud();
return $this->pre_page('#909090',1).$this->mun().$this->next_page('#909090',1);
}
function total_bar($coloro = "#000000", $colorn = "red") //统计数字 页次:1/4310 每页:20 共计:4310页 本页:20
{
return "<font color=$coloro>页次:<font color=$colorn>$this->page</font>/$this->totalpage 每页:<font color=$colorn>$this->pagesize</font> 共计:<font color=$colorn>$this->totalpage</font>页 本页:<font color=$colorn>$this->thispage</font></font>";
}
// 整条导航栏
//页次:1/4310 每页:20 共计:4310页 本页:20 [<<][<][01][02][03][04][05][06][07][08][09][10][>][>>]
function page_bar($coloro = "#000000", $colorn = "red") {
return "<table width='100%' border='0' cellspacing='0'>
<tr>
<td width='5%'></td>
<td width='35%'>".$this->total_bar()."</td>
<td width='40%'align='right'>".$this->mun_bar()."</td>
<td width='10%'>".$this->jump_bar()."</td>
<td width='5%'></td>
</tr>
</table>".$this->mm_jumpmenu();
}
function taketime($color = "#000000") //计算执行时间
{
return "<div align='center'><font color=$color>本页执行时间".abs((microtime()-$this->starttime) * 1000)."毫秒</font></div>";
}
function style() //输出分页的样式
{
$style_num = $this->style;
if ($this->totalpage != 0) //如果总页数=0 ,表示无分页
{
switch($style_num) {
case 1:
return $this->page_bar();
//页次:1/4310 每页:20 共计:4310页 本页:20 [<<][<][01][02][03][04][05][06][07][08][09][10][>][>>]
break;
case 2:
echo $this->mun_bar();
//整条数字导航栏 [<<][<][01][02][03][04][05][06][07][08][09][10][>][>>]
break;
case 3:
echo $this->page_button();
//整条数字导航栏 [<][01][02][03][04][05][06][07][08][09][10][>]
break;
}
}
}
function mm_jumpmenu() //网页特效的跳转
{
//window.open(selobj.options[selobj.selectedindex].value,targ);
return "<script language="javascript">
<!--
function mm_jumpmenu(targ,selobj,restore){
if (selobj.selectedindex==0) return;
window.location.href=selobj.options[selobj.selectedindex].value,targ;
if (restore) selobj.selectedindex=0;
}
//-->
</script>";
}
function first_groud($char = " <<", $color = "#000000") {
if ($this->page == 1) {
return "<font color="".$color."">".$char."</font>";
} else {
//$pre_gpage=($this->page-$this->bar_mid<0)?1:$this->page-$this->bar_mid;
$pre_gpage = 1;
return "<a href="".$_server['php_self']."?".$this->key."page=".$pre_gpage.$this->link."" title="上一组"><font color="".$color."">".$char."</font></a>";
}
}
function last_groud($char = " >>", $color = "#000000") {
if ($this->page == $this->totalpage) {
return "<font color="".$color."">".$char."</font>";
} else {
//$pre_gpage=($this->page-$this->bar_mid<0)?1:$this->page-$this->bar_mid;
$pre_gpage = $this->totalpage;
return "<a href="".$_server['php_self']."?".$this->key."page=".$pre_gpage.$this->link."" title="上一组"><font color="".$color."">".$char."</font></a>";
}
}
}
php mysql分页实现代码
时间: 2024-07-29 10:37:08
php mysql分页实现代码的相关文章
求mysql分页数据库代码
问题描述 急需mysql数据库分页代码请高手们写个完整点的代码小弟万分感激 解决方案 解决方案二:如果使用框架,例如ibatis,可以直接调用框架的API,不需要在数据库上操作分页解决方案三:<%@pagecontentType="text/html;charset=gb2312"language="java"errorPage="../error.jsp"%><scriptlanguage="JavaScript&q
超强 php mysql分页类代码
<?phpclass page { var $page_name="page"; var $next_page='>';//下一页 var $pre_page='<';//上一页 var $first_page='<<首页';//首页 var $last_page='尾页>>';//尾页 var $pre_bar='<<';//上一分页条 var $next_bar='>>';//下一分页条 var $format_le
php5 mysql分页实例代码_php技巧
复制代码 代码如下: <?php //连接数据库 $db=mysql_connect("localhost","root",""); mysql_select_db("hy",$db); //设定每一页显示的记录数 $pagesize=25; //取得记录总数,计算总页数用 $res=mysql_query("select
php mysql 分页显示代码
先我们来看看分页的效果,如果是你想要的就可以下载了. p.php教程分页类的核心代码 代码如下 复制代码 <?php /* php 分页类 只要实现分页.不与数据库教程连接. 如果是伪静态 只需修改84行以下的A标签即可 如 "<a href='index_".$i.".html'>".$i."</a>" (index_表示你的伪静态地址) 其他的A标签页是一样 */ /* 鄙人工作时间写
mysql海量数据分页优化代码
mysql教程海量数据分页优化代码 page 表示页码 pagesize 表示每页的显示数量 conditon 表示一些条件view sourceprint?1 select * from table where conditon order by id limit (page-1)*pagesize,pagesize; 这样分页在早期没有出现什么问题,但当表里的数据达到了100W,慢慢就出现问题了,搜索几百页的时候,经常要用到2秒多 上网搜索了一下,网上的改法可以参考一下,暂时
web开发中PHP+MySQL分页显示示例分析
mysql|web|分页|示例|显示 Web开发是今后分布式程式开发的主流,通常的web开发都要涉及到与数据库打交道,客户端从服务器端读取通常都是以分页的形式来显示,一页一页的阅读起来既方便又美观.所以说写分页程序是web开发的一个重要组成部分,在这里,我们共同来研究分页程序的编写. 一.分页程序的原理 分页程序有两个非常重要的参数:每页显示几条记录($pagesize)和当前是第几页($page).有了这两个参数就可以很方便的写出分页程序,我们以MySql数据库作为数据源,在mysql
php+mysql分页处理的探讨
mysql|分页 php+mysql分页处理的探讨常见的分页处理流程为:1.用select count(*) from tbl_name取得待分页的总记录数2.根据每页的记录数计算出总页数:总页数 = ceil(总记录数/每页记录数)3.根据当前页号计算出起始位置:起始位置 = (当前页号-1)*每页记录数4.用select * from tbl_name limit 起始位置,每页记录数 取得待显示记录5.列表输出相关信息 在这个流程中,数据库需要两次遍历表才能得到所需数据.尽管limit会在
PHP和MySQL分页显示实例分析
Web开发是今后分布式程式开发的主流,通常的web开发都要涉及到与数据库打交道,客户端从服务器端读取通常都是以分页的形式来显示,一页一页的阅读起来既方便又美观.所以说写分页程序是web开发的一个重要组成部分,在这里,我们共同来研究分页程序的编写. 一.分页程序的原理 分页程序有两个非常重要的参数:每页显示几条记录($pagesize)和当前是第几页($page).有了这两个参数就可以很方便的写出分页程序,我们以MySql数据库作为数据源,在mysql里如果要想取出表内某段特定内容可以使用的 T-
.NET分页存储过程代码及使用
最近需要做个论坛,其中用到了分页,如果把整表的数据都查询出来未免小题大做,而且还影响速度 ,所以百度了并私有化了一个分页存储过程,实现了调用. 好了,废话不多说,贴出代码: /**** 使用帮助 首先查询表总行数,再查询分页数据 查询行数传入参数:@doCount,@tblName 查询分页传入参数:@tblName,@PageSize,@PageIndex,@fldName *以上不带查询条件的查询 带条件的加参数:@strWhere *分页查询可以使用排序 参数:@OrderType ***