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,一经查实,立即删除!

相关文章

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

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

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

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

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、 查…

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

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

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

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

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

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

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

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

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

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

使用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…

wireshark分析SIP协议——注册

SIP 是VOIP目前非常流行的一种协议。有关协议的详细原理参照相关文档。本文通过wireshark抓包分析SIP user agent&#xff08;用户代理客户机&#xff0c;uac&#xff09;与SIPserve之间的交互过程&#xff0c;在拨打SIP电话之前&#xff0c;先需要搭建相应的环境&#xff1a;根…

micropython仿真器_Micropython教程之TPYBoard DIY超声波测距仪实例演示

1.实验目的 1. 学习在PC机系统中扩展简单I/O?接口的方法。 2. 进一步学习编制数据输出程序的设计方法。 3. 学习超声波模块的测距原理。 4. 学习LCD5110接线方法 5. 学习TPYboard控制超声波模块测距。(萝卜学科编程教育tpyboard。com) 2.所需元器件 超声波模块一个 TPYBoard板…

monotouch在ipad中的实例应用--显示图像和文字

本节主要讲述在苹果环境中使用monodevelop开发ipad的一个实例&#xff0c;具体操作如下 1、新建项目 选择monotouch--ipad--Empty project 命名为iPad01 2、添加新文件&#xff0c;选择monotouch--ipad view&#xff0c;命名为showView&#xff0c;这样会在项目中多出来三个文件…

MTU MSS 详解记录

先学习理解一下帧的封装格式&#xff1a; 需要注意的是&#xff0c;区别两种帧封装格式&#xff1a;802标准帧和以太网帧1&#xff0c;在802标准定义的帧格式中&#xff0c;长度字段是指它后续数据的字节长度&#xff0c;但不包括C R C检验码。RFC 1042&#xff08;IEEE 802&a…

通达oa 不允许从该ip登陆_通达OA-命令执行漏洞复现

通达OA-命令执行一、环境安装文件&#xff1a;链接:https://pan.baidu.com/s/1Y78Zs-7Igi4MRE0J_Dp-dQ 提取码:2b3i二、漏洞验证任意文件上传漏洞 /ispirit/im/upload.php本地文件包含漏洞 /ispirit/interface/gateway.php这两个路径不需要登录认证。burp抓包修改数据包上传文件…

mysql数据转存到时序数据库_干货丨如何高速迁移MySQL数据到时序数据库DolphinDB...

DolphinDB提供了两种导入MySQL数据的方法&#xff1a;ODBC插件和MySQL插件。我们推荐使用MySQL插件导入MySQL数据&#xff0c;因为它的速度比ODBC导入更快&#xff0c;导入6.5G数据&#xff0c;MySQL插件的速度是ODBC插件的4倍&#xff0c;并且使用MySQL插件无需任何配置&#…

优秀程序员的45个习惯

摘要&#xff1a;值得打印出来贴在办公室墙上学习实践的箴言。 优秀来自好的习惯。怎样成为优秀的开发人员&#xff1f;图灵公司最近热销的《高效程序员的45个习惯》一书给出了很好的解答&#xff0c;非常值得一读。 这本书的英文原版荣获了有软件奥斯卡之称的Jolt生产效率大奖…

java 类型转换_java中的基本数据类型的转换

本文参考了如下两篇文章:Java中&#xff0c;经常可以遇到类型转换的场景&#xff0c;从变量的定义到复制、数值变量的计算到方法的参数传递、基类与派生类间的造型等&#xff0c;随处可见类型转换的身影。Java中的类型转换在Java编码中具有重要的作用。首先&#xff0c;来了解下…

Activity的四种加载模式(转载)

在多Activity开发中&#xff0c;有可能是自己应用之间的Activity跳转&#xff0c;或者夹带其他应用的可复用Activity。可能会希望跳转到原来某个Activity实例&#xff0c;而不是产生大量重复的Activity。这需要为Activity配置特定的加载模式&#xff0c;而不是使用默认的加载模…

centos 安装tomcat_简单介绍Linux配置mysql,tomcat,Nginx 开机自启动的几个方式

概述一般我们打算把一些服务&#xff0c;例如 mysql&#xff0c;tomcat&#xff0c;Nginx设置开机自启动的话一般是有三四种方式来实现&#xff0c;下面以mysql&#xff0c;tomcat&#xff0c;Nginx做例子来演示。一、使用定时任务 cron 命令创建定时任务来运行 .sh 脚本。在sh…