php mysql 实现原理_php+mysql分页原理实现

51e271a3ccecc677a395aac3a2fbc824.jpg

完整代码如下:

!

html

head

-="-type"=";=GBK"

styletype="text/css"

body{font-size:12px;font-family:verdana;width:100%;

}

div.page{

text-align:center;

}

div.content{

height:300px;

}

div.pagea{

border:#aaaadd1pxsolid;text-decoration:none;padding:2px5px2px5px;margin:2px;}

div.pagespan.current{

border:#0000991pxsolid;background-color:#000099;padding:2px5px2px5px;margin:2px;color:#fff;font-weight:bold;}

div.pagespan.disable{

border:#eee1pxsolid;padding:2px5px2px5px;margin:2px;color:#ddd;}

div.pageform{

display:inline;

}

/stylebody?php

//设置级别错误,通知类除外error_reporting('E_ALL~E_NOTICE');

/**1---传入页码,使用GET获取**/$page=$_GET['p'];

/**2---根据页码取出数据:php-mysql处理**/$host="localhost";

$username="root";

$password="";

$db="test";

$pageSize=10;

$showPage=5;

//连接数据库,面向过程$conn=mysqli_connect($host,$username,$password);

if(!$conn){

echo"数据库连接失败";

exit;

}

//选择所要操作的数据库mysqli_select_db($conn,$db);

//设置数据库编码格式mysqli_query($conn,"SETNAMESUTF8");

//编写sql获取分页数据SELECT*FROM表名LIMIT起始位置,显示条数$sql="SELECT*FROMpageorderbyidASCLIMIT".($page-1)*$pageSize.",{$pageSize}";

//把sql语句传送到数据库$result=mysqli_query($conn,$sql);

//将数据显示到table中,并未table设置格式echo"divclass='content'

echo"tableborder=1cellspacing=0width=30%align=center

echo"trtdID/tdtdNAME/td/tr

while($row=mysqli_fetch_assoc($result)){

echo"tr

echo"td{$row['ID']}/td

echo"td{$row['NAME']}/td

echo"tr

}

echo"/table

echo"/div

//释放结果mysqli_free_result($result);

//获取数据总条数$total_sql="SELECTCOUNT(*)FROMpage";

$total_result=mysqli_fetch_array(mysqli_query($conn,$total_sql));

$total=$total_result[0];

$total_pages=ceil($total/$pageSize);

//关闭数据库mysqli_close($conn);

/**3---显示数据+显示分页条**/$page_banner="divclass='page'

//计算偏移量$pageoffset=($showPage-1)/2;

//两种情况下首页、上一页的显示效果if($page1){

$page_banner.="ahref='".$_SERVER['PHP_SELF']."?p=1'首页/a

$page_banner.="ahref='".$_SERVER['PHP_SELF']."?p=".($page-1)."'上一页/a

}else{

$page_banner.="spanclass='disable'首页/span

$page_banner.="spanclass='disable'上一页/span

}

//显示$start=1;

$end=$total_pages;

//当总条数大于分页数时if($total_pages$showPage){

if($page$pageoffset+1){

$page_banner.="...";

}

if($page$pageoffset){

$start=$page-$pageoffset;

$end=$total_pages$page+$pageoffset?$page+$pageoffset:$total_pages;//三段式}

//最前面几个特殊页号的显示。当前指的是页号1或者2时else{

$start=1;

$end=$showPage;

}

//最后面几个特殊页号的显示,当前显示的是页号7和8if($page+$pageoffset$total_pages){

$start=$start-($page+$pageoffset-$end);//注意理解这一句}

}

//显示页码for($i=$start;$i=$end;$i++){

//当前页页码上显示背景色if($page==$i){

$page_banner.="spanclass='current'{$i}/span

}

//非当前页码显示else{

$page_banner.="ahref='".$_SERVER['PHP_SELF']."?p=".$i."'{$i}/a

}

}

if($total_pages$showPage$total_pages$page+$pageoffset){

$page_banner.="...";

}

//两种情况下的尾页、下一页的显示效果if($page$total_pages){

$page_banner.="ahref='".$_SERVER['PHP_SELF']."?p=".($page+1)."'下一页/a

$page_banner.="ahref='".$_SERVER['PHP_SELF']."?p=$total_pages'尾页/a

}else{

$page_banner.="spanclass='disable'尾页/span

$page_banner.="spanclass='disable'下一页/span

}

$page_banner.="共{$total_pages}页,";

$page_banner.="formaction='mypage.php'method='get'

$page_banner.="到第inputtype='text'size=2value='1'name='p'页";

$page_banner.="inputtype='submit'value='确定'

$page_banner.="/form

$page_banner.="/div

echo$page_banner;

?/body/html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/434211.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Tiny6410上安装debian基本系统的过程

Tiny6410上安装debian基本系统的过程:注:debootstrap工具可以在已有的任何linux中使用,不过建议用debian或其衍生系统(如ubuntu等),以下步骤可以在电脑上做,也可以直接在Tiny6410上做,不过很慢,…

python任意代码都可以缩进去_我发现了个 Python 黑魔法,执行任意代码都会自动念上一段 『平安经』...

最近的"平安经"可谓是引起了不小的风波啊。作为一个正儿八经的程序员,最害怕的就是自己的代码上线出现各种各样的 BUG。为此,明哥今天分享一个 Python 的黑魔法,教你如何在你执行任意 Python 代码前,让 Python 解释器自…

域用户更改密码提示拒绝访问_AD域中的ACL攻防探索

前言关于域内ACL的攻防近两年经常被人所提起,同时也产生了很多关于域内ACL相关的工具和攻击方式,本文将会从ACL的概念谈起,然后介绍几种不同的域内攻击方式以及如何监测和防御对于ACL的攻击。ACL的概念和作用ACM:首先想要了解ACL首…

Codeforces Round #143 (Div. 2) C

http://codeforces.com/contest/231/problem/C 昨天的cf。比赛的时候其实有点思路的,但是因为B搞错方向了没敢写C。刚刚写了下,AC了。用的思路还真是昨天晚上的。囧。昨天晚上看的时候有一个地方不知道怎么转换,就是怎么快速求出i-->ians需…

go MySQL 多语句_八、MySQL经典查询语句-Go语言中文社区

student表course表score表teacher表1、 查询Student表中的所有记录的Sname、Ssex和Class列。select Sname,Ssex,Class from Student;2、 查询教师所有的单位即不重复的Depart列。select distinct Depart from Teacher3、 查询Student表的所有记录。select * from Student4、 查…

ffmpeg编译 MingW + MSYS

环境要求: MinGW:5.1.4 make: 3.81 gcc: 4.3.2 w32api: 3.13 SDL: 1.2.1 MinGW-Runtime:3.15 1.Minimal SYStem (MSYS) 安装 下载MSYS-1.0.10.exe并安装:下载地址:http://downl…

如何干净的删除vm_如何在macOS 10.15 Catalina绕过XProtect?

在macOS 10.15 Catalina中,Apple进行了许多安全性能地改进,包括通过使所有可执行文件都受XProtect扫描来加固系统,而不管文件是否带有com.apple.quarantine位标记。对于安全研究人员而言,这意味着不再像以前的macOS一样&#xff0…

vtun中setsockopt fcntl等有关套接字设置

client.c文件中在建立socket后有一句 setsockopt(s, SOL_SOCKET, SO_REUSEADDR, &opt, sizeof(opt)); SO_REUSEADDR允许重用本地地址。 client.c文件在bind之后的connec_t函数中, 先将socket设为非阻塞,然后connect 然后select然后再将socket状态改为…

mysql行级锁作用_Mysql事务及行级锁的理解

在最近的开发中,碰到一个需求签到,每个用户每天只能签到一次,那么怎么去判断某个用户当天是否签到呢?因为当属表设计的时候,每个用户签到一次,即向表中插入一条记录,根据记录的数量和时间来判断…

activexobject对象不能创建_Oracle数据库用户管理之系统权限和对象权限

【关键术语】Privileges 权限System privileges 系统权限Object privileges 对象权限Grant 授予Revoke 撤消2.1 Oracle 权限概述2.1.1 权限的作用权限(privilege)是指执行特定类型 SQL 命令或访问其他模式对象的权利。Oracle 使用 权限来控制用户对数据的访问以及用户所能执行的…

视频文件大小计算

1.每小时录像文件大小计算公式: 码率大小*3600/8/1024 MB/小时。2.硬盘录像机硬盘容量计算公式: 每小时录像文件大小*每天录像时间(时)*硬盘录像机路数*需要保存的天数。例如:8路硬盘录像机,音视频录像,采用512Kbps定…

【啃不完的算法导论】- 动态规划 - 最长公共子序列(概念篇)

以下内容纯是为了熟悉《算法导论》中的内容,高手可略过,其中涉及的书本内容的版权归原作者、译者、出版社所有 求最长公共子序列,一个典型的 动态规划题 和 字符串处理算法,写在这里是希望自己以后能多来看看和改改,温…

python发送邮箱_你知道怎么用Python发送邮件吗?

作者 | 陈熹来源 | 早起Python(ID:zaoqi-python)头图 | CSDN 下载自东方IC前言本文主要对邮件操作基础知识及代码进行介绍,用Python发邮件有哪些优势?批量发送邮件,并且各邮件可以不同高度自定义的定时发送更有效地管理收件箱基本…

解决 avformat_alloc_context无法识别的问题

由于最近库更新,如果还是用原来的测试用例会碰到avformat_alloc_context 无法识别的问题 avformat_alloc_context is cannot indentified。 解决办法就是将 ocavformat_alloc_context 改成 ocav_alloc_format_context(); 就ok啦 注:我用的库是FFmpeg-full-SD…

python去空格的函数_Python怎么去掉最后的空格

strip()函数 去空格nrt函数的用法 strip 同时去掉左右两边的空格(推荐学习:Python视频教程) lstrip 去掉左边的空格 rstrip 去掉右边的空格 具体示例如下:>>>a" hello world!! " >&g…

Java中getResource()的用法

用JAVA获取文件,听似简单,但对于很多像我这样的新人来说,还是掌握颇浅,用起来感觉颇深,大常最经常用的,就是用JAVA的File类,如要 取得c:/test.txt文件,就会这样用File file new Fil…

centos中安装mysql5.6_CentOS中安装MySQL5.6报错的解决方法

由于项目需要,必须使用最新出来的MySQL5.6社区版本,使用的操作系统是CentOS6.3。然后安装到中途报错如下:file /usr/share/mys由于项目需要,必须使用最新出来的MySQL5.6社区版本,使用的操作系统是CentOS6.3。首先&…

python逻辑运算符不懂_Python之逻辑运算符

这一小节我在动笔之前犹豫到底要不要动手写,虽然简单但是防止遗忘,博主还是决定记录一下。Python中运算符主要分为算术运算符,赋值运算符,比较运算符,逻辑运算符以及成员运算符。下面详细记录这5种运算符。 1. 算术运算…

使用Wireshark进行SIP包解析

1. 安装Wireshark 下载Wireshark后,安装很简单,基本上只需要点击“Next”和“I agree”等按钮,不再赘述。 2. Wireshark介绍 参见:http://man.lupaworld.com/content/network/wireshark/Introduction.html copy一下简要介绍&a…

Android-Animations的使用大全之二:Frame Animation和其他

Android-Animations的使用大全之一&#xff1a;Tweened Animations详解 5 Frame-By-Frame Animations的使用方 1 在res/drawable中创建一个xml文件&#xff0c;定义Animation的动画播放序列 anim_nv.xml Xml代码 <animation-list xmlns:android"http://schemas.androi…