用PHP实现ODBC数据分页显示一例


Posted in PHP onOctober 09, 2006

$pagesize = 2; //一页显示记录数

$con = odbc_connect("access_test","","",SQL_CUR_USE_ODBC) or die("无法连接ODBC数据源access_test"); //连接一个ODBC数据源
$sql = "select count(*) as total from test"; //取得记录总数SQL语句
$rst = odbc_exec($con,$sql) or die("$sql查询出错"); //执行取得记录总数SQL语句
$recordcount = odbc_result($rst,1); //取得记录总数,在这里也可以用$recordcount = odbc_result($rst,"total");
odbc_free_result($rst); //释放资源

$pagecount = bcdiv($recordcount+$pagesize-1,$pagesize,0); //算出总页数

if(!isset($page)) $page = 1; //如果没有指定显示页码,缺省为显示第一页
if($page<1) $page = 1; //如果页码比1小,则显示第一页
if($page>$pagecount) $page = $pagecount; //如果页码比总页数大,则显示最后一页

if($page>0){ //页码比0大,表示有数据
   echo '>> 分页 ';
   echo '<a href="' . $PHP_SELF . '?page=1">首页</a> ';
   if($page>1){
      echo '<a href="' . $PHP_SELF . '?page='. ($page-1) . '">前页</a> ';
   }
   else{
      echo '前页 ';
   }
   if($page<$pagecount){
      echo '<a href="' . $PHP_SELF . '?page='. ($page+1) . '">后页</a> ';
   }
   else{
      echo '后页 ';
   }
   echo '<a href="' . $PHP_SELF . '?page=' . $pagecount . '">尾页</a> ';
   echo '页次: ' . $page . '/' . $pagecount . '页 ';
   echo $pagesize . '条/页 ';
   echo '共' . $recordcount . '条 ';

   $sql = "select * from test"; //取得数据SQL语句
   $rst = odbc_exec($con,$sql) or die("$sql查询出错"); //执行取得数据SQL语句

   $fieldcount = odbc_num_fields($rst); //取得字段总数

   echo '<table border="1" cellspacing="0" cellpadding="0">';
   echo '<tr>';
   for($i=1;$i<=$fieldcount;$i++){
      echo '<th>' . odbc_field_name($rst,$i) . '</th>'; //显示第$i个字段名
   }
   echo '</tr>';
   $rowi = ($page-1)*$pagesize+1;
   for($i=0;$i<$pagesize;$i++){
      echo '<tr>';
      if($rowi>$recordcount){
         for($j=0;$j<$fieldcount;$j++){
            echo '<td> </td>';
         }
      }
      else{
         odbc_fetch_into($rst,$rowi,&$row);
         for($j=0;$j<$fieldcount;$j++){
            $field = $row[$j];
            if($field=='') $field = ' ';
            echo '<td>' . $field  . '</td>';
         }
         $rowi = $rowi+1;
      }
      echo '</tr>';
   }
   echo '</table>';

   odbc_free_result($rst); //释放资源
}
else{
   echo "无数据";
}

odbc_close($con); //关闭连接并释放资源
?>

PHP 相关文章推荐
php的chr和ord函数实现字符加减乘除运算实现代码
Dec 05 PHP
用PHP代替JS玩转DOM的思路及示例代码
Jun 15 PHP
php创建、获取cookie及基础要点分析
Jan 26 PHP
PHP速成大法
Jan 30 PHP
php实现递归的三种基本方式
Jul 04 PHP
PHP QRCODE生成彩色二维码的方法
May 19 PHP
Smarty简单生成表单元素的方法示例
May 23 PHP
php日期操作技巧小结
Jun 25 PHP
PHP中多线程的两个实现方法
Oct 14 PHP
php文件上传及下载附带显示文件及目录功能
Apr 27 PHP
PHP缓存工具XCache安装与使用方法详解
Apr 09 PHP
Laravel 手动开关 Eloquent 修改器的操作方法
Dec 30 PHP
使用 php4 加速 web 传输
Oct 09 #PHP
php 中include()与require()的对比
Oct 09 #PHP
php生成WAP页面
Oct 09 #PHP
让你同时上传 1000 个文件 (一)
Oct 09 #PHP
让你同时上传 1000 个文件 (二)
Oct 09 #PHP
一个可以删除字符串中HTML标记的PHP函数
Oct 09 #PHP
利用static实现表格的颜色隔行显示
Oct 09 #PHP
You might like
全国FM电台频率大全 - 13 福建省
2020/03/11 无线电
使PHP自定义函数返回多个值
2006/11/26 PHP
PHP实现数字补零功能的2个函数介绍
2014/05/12 PHP
php实现微信原生支付(扫码支付)功能
2018/05/30 PHP
Laravel 错误提示本地化的实现
2019/10/22 PHP
基于laravel缓冲cache的用法详解
2019/10/23 PHP
javascript:以前写的xmlhttp池,代码
2008/05/18 Javascript
为jQuery.Treeview添加右键菜单的实现代码
2010/10/22 Javascript
jquery eval解析JSON中的注意点介绍
2013/08/23 Javascript
基于JavaScript代码实现微信扫一扫下载APP
2015/12/30 Javascript
全面了解javascript中的错误处理机制
2016/07/18 Javascript
AngularJS基础 ng-keydown 指令简单示例
2016/08/02 Javascript
JavaScript表单验证的两种实现方法
2017/02/11 Javascript
js实现滑动到页面底部自动加载更多功能
2017/02/15 Javascript
原生JS京东轮播图代码
2017/03/22 Javascript
JS实现AES加密并与PHP互通的方法分析
2017/04/19 Javascript
ES6新特性二:Iterator(遍历器)和for-of循环详解
2017/04/20 Javascript
bootstrap栅格系统示例代码分享
2017/05/22 Javascript
jQuery Ajax使用FormData上传文件和其他数据后端web.py获取
2017/06/11 jQuery
微信小程序 跳转传递数据的实例
2017/07/06 Javascript
JavaScript实现单例模式实例分享
2017/12/22 Javascript
以v-model与promise两种方式实现vue弹窗组件
2018/05/21 Javascript
JavaScript实现仿Clock ISO时钟
2018/06/29 Javascript
layui问题之模拟select点击事件的实例讲解
2018/08/15 Javascript
Jquery实现获取子元素的方法分析
2019/08/24 jQuery
vue 项目打包时样式及背景图片路径找不到的解决方式
2019/11/12 Javascript
js判断非127开头的IP地址的实例代码
2020/01/05 Javascript
详谈Python2.6和Python3.0中对除法操作的异同
2017/04/28 Python
Python 批量合并多个txt文件的实例讲解
2018/05/08 Python
django foreignkey外键使用的例子 相当于left join
2019/08/06 Python
python+mysql实现个人论文管理系统
2019/10/25 Python
python用quad、dblquad实现一维二维积分的实例详解
2019/11/20 Python
python创建学生成绩管理系统
2019/11/22 Python
Python:合并两个numpy矩阵的实现
2019/12/02 Python
python 对xml解析的示例
2021/02/27 Python
美国奢侈品购物平台:Orchard Mile
2018/05/02 全球购物