php大数据分页查询 php实现分页查询

怎么做php数据库调取数据分页显示,要php的?php
include("connection.php");
$perNumber=10; //每页显示php大数据分页查询的记录数
$page=$_GET['page']; //获得当前php大数据分页查询的页面值
$count=mysql_query("select count(*) from user"); //获得记录总数
$rs=mysql_fetch_array($count);
$totalNumber=$rs[0];
$totalPage=ceil($totalNumber/$perNumber); //计算出总页数
if (!isset($page)) {
$page=1;
} //如果没有值,则赋值1
$startCount=($page-1)*$perNumber; //分页开始,根据此方法计算出开始php大数据分页查询的记录
$result=mysql_query("select * from user limit $startCount,$perNumber"); //根据前面的计算出开始的记录和记录数
while ($row=mysql_fetch_array($result)) {
echo "user_id:".$row[0]."br";
echo "username:".$row[1]."br"; //显示数据库的内容
}
if ($page != 1) { //页数不等于1
?
a href="https://www.04ip.com/post/fenye.php?page=?php echo $page - 1;?"上一页/a !--显示上一页--
?php
}
for ($i=1;$i=$totalPage;$i) {//循环显示出页面
?
a href="https://www.04ip.com/post/fenye.php?page=?php echo $i;?"?php echo $i ;?/a
?php
}
if ($page$totalPage) { //如果page小于总页数,显示下一页链接
?
a href="https://www.04ip.com/post/fenye.php?page=?php echo $page1;?"下一页/a
?php
}
?
================================
这个是很简单的..而且也写php大数据分页查询了注释..不知道合不合php大数据分页查询你的意..
php 百万数据分表后怎么做分页需要请求时携带页码参数php大数据分页查询,也就是客户端get或者post请求时携带php大数据分页查询的页码参数 。剩余php大数据分页查询的功能与做页面时分页一样 。如果需要数据库查询的话php大数据分页查询,limit实现 。比如:query($sql);略
如何将php里面的数组内容进行分页显示出来?1、前言
分页显示是一种非常常见的浏览和显示大量数据的方法,属于web编程中最常处理的事件之一 。对于web编程的老手来说,编写这种代码实在是和呼吸一样自然,但是对于初学者来说,常常对这个问题摸不着头绪 , 因此特地撰写此文对这个问题进行详细的讲解,力求让看完这篇文章的朋友在看完以后对于分页显示的原理和实现方法有所了解 。本文适合初学者阅读 , 所有示例代码均使用php编写 。
2、原理
所谓分页显示,也就是将数据库中的结果集人为的分成一段一段的来显示,这里需要两个初始的参数:
每页多少条记录($PageSize)?
当前是第几页($CurrentPageID)?
现在只要再给我一个结果集 , 我就可以显示某段特定的结果出来 。
至于其他的参数 , 比如:上一页($PreviousPageID)、下一页($NextPageID)、总页数($numPages)等等,都可以根据前边这几个东西得到 。
以mysql数据库为例,如果要从表内截取某段内容,sql语句可以用:select * from table limit offset, rows 。看看下面一组sql语句 , 尝试一下发现其中的规率 。
前10条记录:select * from table limit 0,10
第11至20条记录:select * from table limit 10,10
第21至30条记录:select * from table limit 20,10
……
这一组sql语句其实就是当$PageSize=10的时候取表内每一页数据的sql语句 , 我们可以总结出这样一个模板:
select * from table limit ($CurrentPageID - 1) * $PageSize, $PageSize
拿这个模板代入对应的值和上边那一组sql语句对照一下看看是不是那么回事 。搞定了最重要的如何获取数据的问题以后,剩下的就仅仅是传递参数,构造合适的sql语句然后使用php从数据库内获取数据并显示了 。以下我将用具体代码加以说明 。
3、简单代码
请详细阅读以下代码,自己调试运行一次 , 最好把它修改一次,加上自己的功能,比如搜索等等 。
?php
// 建立数据库连接
$link = mysql_connect("localhost", "mysql_user", "mysql_password")
or die("Could not connect: " . mysql_error());
// 获取当前页数
if( isset($_GET['page']) ){
$page = intval( $_GET['page'] );
}
else{
$page = 1;
}
// 每页数量
$PageSize = 10;
// 获取总数据量
$sql = "select count(*) as amount from table";
$result = mysql_query($sql);
$row = mysql_fetch_row($result);
$amount = $row['amount'];
// 记算总共有多少页
if( $amount ){
if( $amount$page_size ) //如果总数据量小于$PageSize,那么只有一页
if( $amount % $page_size ){ //取总数据量除以每页数的余数
$page_count = (int)($amount / $page_size)1; //如果有余数,则页数等于总数据量除以每页数的结果取整再加一
}else{
$page_count = $amount / $page_size; //如果没有余数,则页数等于总数据量除以每页数的结果
}
}
else{
$page_count = 0;
}
// 翻页链接
$page_string = '';
if( $page == 1 ){
$page_string .= '第一页|上一页|';
}
else{
$page_string .= 'a href="https://www.04ip.com/?page=1";第一页/a|a href="https://www.04ip.com/?page='."($page-1).'上一页/a|';
}
if( ($page == $page_count) || ($page_count == 0) ){
$page_string .= '下一页|尾页';
}
else{
$page_string .= 'a href="https://www.04ip.com/?page='."($page 1).'下一页/a|a href="https://www.04ip.com/?page='."$page_count.'尾页/a';
}
// 获取数据,以二维数组格式返回结果
if( $amount ){
$sql = "select * from table order by id desc limit ". ($page-1)*$page_size .", $page_size";
$result = mysql_query($sql);
while ( $row = mysql_fetch_row($result) ){
$rowset[] = $row;
}
}else{
$rowset = array();
}
// 没有包含显示结果的代码,那不在讨论范围 , 只要用foreach就可以很简单的用得到的二维数组来显示结果
?
4、OO风格代码
以下代码中的数据库连接是使用的pear db类进行处理
?php
// FileName: Pager.class.php
// 分页类,这个类仅仅用于处理数据结构,不负责处理显示的工作
Class Pager
{
var $PageSize; //每页的数量
var $CurrentPageID; //当前的页数
var $NextPageID; //下一页
var $PreviousPageID; //上一页
var $numPages; //总页数
var $numItems; //总记录数
var $isFirstPage; //是否第一页
var $isLastPage; //是否最后一页
var $sql; //sql查询语句
function Pager($option)
{
global $db;
$this-_setOptions($option);
// 总条数
if ( !isset($this-numItems) )
{
$res = $db-query($this-sql);
$this-numItems = $res-numRows();
}
// 总页数
if ( $this-numItems0 )
{
if ( $this-numItems$this-PageSize )
if ( $this-numItems % $this-PageSize )
{
$this-numPages= (int)($this-numItems / $this-PageSize)1;
}
else
{
$this-numPages = $this-numItems / $this-PageSize;
}
}
else
{
$this-numPages = 0;
}
switch ( $this-CurrentPageID )
{
case $this-numPages == 1:
$this-isFirstPage = true;
$this-isLastPage = true;
break;
case 1:
$this-isFirstPage = true;
$this-isLastPage = false;
break;
case $this-numPages:
$this-isFirstPage = false;
$this-isLastPage = true;
break;
default:
$this-isFirstPage = false;
$this-isLastPage = false;
}
if ( $this-numPages1 )
{
if ( !$this-isLastPage )
if ( !$this-isFirstPage )
}
return true;
}
/***
*
* 返回结果集的数据库连接
* 在结果集比较大的时候可以直接使用这个方法获得数据库连接,然后在类之外遍历,这样开销较小
* 如果结果集不是很大 , 可以直接使用getPageData的方式获取二维数组格式的结果
* getPageData方法也是调用本方法来获取结果的
*
***/
function getDataLink()
{
if ( $this-numItems )
{
global $db;
$PageID = $this-CurrentPageID;
$from = ($PageID - 1)*$this-PageSize;
$count = $this-PageSize;
$link = $db-limitQuery($this-sql, $from, $count); //使用Pear DB::limitQuery方法保证数据库兼容性
return $link;
}
else
{
return false;
}
}
/***
*
* 以二维数组的格式返回结果集
*
***/
function getPageData()
{
if ( $this-numItems )
{
if ( $res = $this-getDataLink() )
{
if ( $res-numRows() )
{
while ( $row = $res-fetchRow() )
{
$result[] = $row;
}
}
else
{
$result = array();
}
return $result;
}
else
{
return false;
}
}
else
{
return false;
}
}
function _setOptions($option)
{
$allow_options = array(
'PageSize',
'CurrentPageID',
'sql',
'numItems'
);
foreach ( $option as $key = $value )
{
if ( in_array($key, $allow_options)($value != null) )
{
$this-$key = $value;
}
}
return true;
}
}
?
?php
// FileName: test_pager.php
// 这是一段简单的示例代码,前边省略了使用pear db类建立数据库连接的代码
require "Pager.class.php";
if ( isset($_GET['page']) )
{
$page = (int)$_GET['page'];
}
else
{
$page = 1;
}
$sql = "select * from table order by id";
$pager_option = array(
"sql" = $sql,
"PageSize" = 10,
"CurrentPageID" = $page
);
if ( isset($_GET['numItems']) )
{
$pager_option['numItems'] = (int)$_GET['numItems'];
}
$pager = @new Pager($pager_option);
$data = https://www.04ip.com/post/$pager-getPageData();
if ( $pager-isFirstPage )
{
$turnover = "首页|上一页|";
}
else
{
$turnover = "a href='https://www.04ip.com/post/?page=1numItems=".$pager-numItems."'首页/a|a href="https://www.04ip.com/?page=".$pager-PreviousPageID."numItems=".$pager-numItems."'上一页/a|";
}
if ( $pager-isLastPage )
{
$turnover .= "下一页|尾页";
}
else
{
$turnover .= "a href="https://www.04ip.com/?page=".$pager-NextPageID."numItems=".$pager-numItems."'下一页/a|a href="https://www.04ip.com/?page=".$pager-numPages."numItems=".$pager-numItems."'尾页/a";
}
?
需要说明的地方有两个:
这个类仅仅处理数据,并不负责处理显示,因为我觉得将数据的处理和结果的显示都放到一个类里边实在是有些勉强 。显示的时候情况和要求多变,不如自己根据类给出的结果处理,更好的方法是根据这个Pager类继承一个自己的子类来显示不同的分页,比如显示用户分页列表可以:
?php
Class MemberPager extends Pager
{
function showMemberList()
{
global $db;
$data = https://www.04ip.com/post/$this-getPageData();
// 显示结果的代码
// ......
}
}
/// 调用
if ( isset($_GET['page']) )
{
$page = (int)$_GET['page'];
}
else
{
$page = 1;
}
$sql = "select * from members order by id";
$pager_option = array(
"sql" = $sql,
"PageSize" = 10,
"CurrentPageID" = $page
);
if ( isset($_GET['numItems']) )
{
$pager_option['numItems'] = (int)$_GET['numItems'];
}
$pager = @new MemberPager($pager_option);
$pager-showMemberList();
?
第二个需要说明的地方就是不同数据库的兼容性,在不同的数据库里截获一段结果的写法是不一样的 。
mysql: select * from table limit offset, rows
pgsql: select * from table limit m offset n
......
所以要在类里边获取结果的时候需要使用pear db类的limitQuery方法 。
ok,写完收功,希望花时间看完这些文字的你不觉得是浪费了时间 。
回答者
另外,虚机团上产品团购,超级便宜
PHP中查找数据库的数据然后在php页面分页显示,只能显示第一页的数据你的页面跳转 , 要把原来有的get参数一同传递下去!
因为,如果你第一页就是根据相关get参数查询的数据库,而你在下一页没有提供这个参数 , 当然会查询不到!
get参数是在当前页面有效的,一般 , get参数是url提供,你url有就有 , 没有就没有 , 不是你提供一次,人家就会给你保存一辈子!
例外,你这个php文件,功能其实很简单对吧?但你有没有觉得,代码密密麻麻呢?
如果让你写一个大型网站 , 那你的代码岂不是要用东风牌大卡车来装呢?
php 多条件 分页查询条件丢失 怎么解决?php
//====================================================
//FileName: page.class.php
//Summary:系统分页配置
//====================================================
class page {
/**
* config ,public
*/
var $page_name="pageNum";//page标签,用来控制url页 。比如说xxx.php?PB_page=2中的PB_page
var $next_page='';//下一页
var $pre_page='';//上一页
var $first_page='First';//首页
var $last_page='Last';//尾页
var $pre_bar='';//上一分页条
var $next_bar='';//下一分页条
var $format_left=' ';
var $format_right=' ';
var $is_ajax=False;//是否支持AJAX分页模式
/**
* private
*
*/
var $pagebarnum=10;//控制记录条的个数 。
var $totalpage=0;//总页数
var $ajax_action_name='';//AJAX动作名
var $nowindex=1;//当前页
var $url="";//url地址头
var $offset=0;
/**
* constructor构造函数
*
* @param array $array['total'],$array['perpage'],$array['nowindex'],$array['url'],$array['ajax']...
*/
function page($array){
if(is_array($array)){
if(!array_key_exists('total',$array))$this-error(__FUNCTION__,'need a param of total');
$total=intval($array['total']);
$perpage=(array_key_exists('perpage',$array))?intval($array['perpage']):10;
$nowindex=(array_key_exists('nowindex',$array))?intval($array['nowindex']):'';
$url=(array_key_exists('url',$array))?$array['url']:'';
}else{
$total=$array;
$perpage=10;
$nowindex='';
$url='';
}
if((!is_int($total))||($total0))$this-error(__FUNCTION__,$total.' is not a positive integer!');
if((!is_int($perpage))||($perpage=0))$this-error(__FUNCTION__,$perpage.' is not a positive integer!');
if(!empty($array['page_name']))$this-set('page_name',$array['page_name']);//设置pagename
$this-_set_nowindex($nowindex);//设置当前页
$this-_set_url($url);//设置链接地址
$this-totalpage=ceil($total/$perpage);
$this-offset=($this-nowindex-1)*$this-perpage;
if(!empty($array['ajax']))$this-open_ajax($array['ajax']);//打开AJAX模式
}
/**
* 设定类中指定变量名的值,如果改变量不属于这个类,将throw一个exception
*
* @param string $var
* @param string $value
*/
function set($var,$value){
if(in_array($var,get_object_vars($this)))
$this-$var=$value;
else {
$this-error(__FUNCTION__,$var." does not belong to PB_Page!");
}
}
/**
* 打开倒AJAX模式
*
* @param string $action 默认ajax触发的动作 。
【php大数据分页查询 php实现分页查询】*/
function open_ajax($action){
$this-is_ajax=true;
$this-ajax_action_name=$action;
}
/**
* 获取显示"下一页"的代码
*
* @param string $style
* @return string
*/
function next_page($style=''){
if($this-nowindex$this-totalpage){
return "li".$this-_get_link($this-_get_url($this-nowindex 1),$this-next_page,$style)."/li";
}
return "li class='active'span".$this-next_page."/span/li";
}
/**
* 获取显示“上一页”的代码
*
* @param string $style
* @return string
*/
function pre_page($style=''){
if($this-nowindex1){
return "li".$this-_get_link($this-_get_url($this-nowindex-1),$this-pre_page,$style)."/li";
}
return "li class='active'span".$this-pre_page."/span/li";
}
/**
* 获取显示“首页”的代码
*
* @return string
*/
function first_page($style=''){
if($this-nowindex==1){
return "li class='active'span".$this-first_page."/span/li";
}
return "li".$this-_get_link($this-_get_url(1),$this-first_page,$style)."/li";
}
/**
* 获取显示“尾页”的代码
*
* @return string
*/
function last_page($style='lastpage'){
if($this-nowindex==$this-totalpage){
return "li class='active'span".$this-last_page."/span/li";
}
return "li".$this-_get_link($this-_get_url($this-totalpage),$this-last_page,$style)."/li";
}
function nowbar($style='',$nowindex_style='current'){
$plus=ceil($this-pagebarnum/2);
if($this-pagebarnum-$plus $this-nowindex$this-totalpage)$plus=($this-pagebarnum-$this-totalpage $this-nowindex);
$begin=$this-nowindex-$plus 1;
$begin=($begin=1)?$begin:1;
$return='';
for($i=$begin;$i$begin $this-pagebarnum;$i)
{
if($i=$this-totalpage){
if($i!=$this-nowindex)
$return.=$this-_get_text("li".$this-_get_link($this-_get_url($i),$i,$style)."/li");
else
$return.=$this-_get_text("li class='active'span class='".$nowindex_style."'".$i."/span/li");
}else{
break;
}
$return.="\n";
}
unset($begin);
return $return;
}
/**
* 获取显示跳转按钮的代码
*
* @return string
*/
function select(){
$return="select name=\"jumpMenu\" id=\"jumpMenu\" onchange=\"MM_jumpMenu('window',this,0)\"";
for($i=1;$i=$this-totalpage;$i)
{
if($i==$this-nowindex){
if(strip_tags($_GET[cid],'')==""){
$return.="option value=https://www.04ip.com/"?" .$this-page_name . "=".$i."\" selected".$i."/option";
}else{
$return.="option value=https://www.04ip.com/"?cid=".strip_tags($_GET[cid],'')."" .$this-page_name . "=".$i."\" selected".$i."/option";
}
}else{
if(strip_tags($_GET[cid],'')==""){
$return.="option value=https://www.04ip.com/"?" .$this-page_name . "=".$i."\"".$i."/option";
}else{
$return.="option value=https://www.04ip.com/"?cid=".strip_tags($_GET[cid],'')."" .$this-page_name . "=".$i."\" ".$i."/option";
}
}
}
unset($i);
$return.='/select';
return $return;
}
/**
* 获取mysql 语句中limit需要的值
*
* @return string
*/
function offset(){
return $this-offset;
}
/**
* 控制分页显示风格(你可以增加相应的风格)
*
* @param int $mode
* @return string
*/
function show($mode=1){
switch ($mode)
{
case '1':
$this-first_page='首页';
$this-last_page='尾页';
$this-next_page='下一页';
$this-pre_page='上一页';
return $this-first_page()." ".$this-pre_page()." ".$this-nowbar()." ".$this-next_page()." ".$this-last_page();
break;
case '2':
$this-next_page='下一页';
$this-pre_page='上一页';
$this-first_page='首页';
$this-last_page='尾页';
return $this-first_page().$this-pre_page().'[第'.$this-nowindex.'页]'.$this-next_page().$this-last_page().'第'.$this-select().'页';
break;
case '3':
$this-next_page='下一页';
$this-pre_page='上一页';
$this-first_page='首页';
$this-last_page='尾页';
return $this-first_page().$this-pre_page().$this-next_page().$this-last_page();
break;
case '4':
$this-next_page='下一页';
$this-pre_page='上一页';
return $this-pre_page().$this-nowbar().$this-next_page();
break;
case '5':
return $this-pre_bar().$this-pre_page().$this-nowbar().$this-next_page().$this-next_bar();
break;
}
}
/*----------------private function (私有方法)-----------------------------------------------------------*/
/**
* 设置url头地址
* @param: String $url
* @return boolean
*/
function _set_url($url=""){
if(!empty($url)){
//手动设置
$this-url=$url.((stristr($url,'?'))?'':'?').$this-page_name."=";
}else{
//自动获取
if(empty($_SERVER['QUERY_STRING'])){
//不存在QUERY_STRING时
$this-url=$_SERVER['REQUEST_URI']."?".$this-page_name."=";
}else{
//
if(stristr($_SERVER['QUERY_STRING'],$this-page_name.'=')){
//地址存在页面参数
$this-url=str_replace($this-page_name.'='.$this-nowindex,'',$_SERVER['REQUEST_URI']);
$last=$this-url[strlen($this-url)-1];
if($last=='?'||$last==''){
$this-url.=$this-page_name."=";
}else{
$this-url.=''.$this-page_name."=";
}
}else{
//
$this-url=$_SERVER['REQUEST_URI'].''.$this-page_name.'=';
}
}
}
}
/**
* 设置当前页面
*
*/
function _set_nowindex($nowindex){
if(empty($nowindex)){
//系统获取
if(isset($_GET[$this-page_name])){
$this-nowindex=intval($_GET[$this-page_name]);
}
}else{
//手动设置
$this-nowindex=intval($nowindex);
}
}
/**
* 为指定的页面返回地址值
*
* @param int $pageno
* @return string $url
*/
function _get_url($pageno=1){
return $this-url.$pageno;
}
/**
* 获取分页显示文字,比如说默认情况下_get_text('a href=""1/a')将返回[a href=""1/a]
*
* @param String $str
* @return string $url
*/
function _get_text($str){
return $this-format_left.$str.$this-format_right;
}
/**
* 获取链接地址
*/
function _get_link($url,$text,$style=''){
$style=(empty($style))?'':'class="'.$style.'"';
if($this-is_ajax){
//如果是使用AJAX模式
return 'a '.$style.' href="javascript:'.$this-ajax_action_name.'(\''.$url.'\')"'.$text.'/a';
}else{
return 'a '.$style.' href="'.$url.'"'.$text.'/a';
}
}
/**
* 出错处理方式
*/
function error($function,$errormsg){
die('Error in file b'.__FILE__.'/b ,Function b'.$function.'()/b :'.$errormsg);
}
}
?
关于php大数据分页查询和php实现分页查询的介绍到此就结束了 , 不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息 , 记得收藏关注本站 。

    推荐阅读