通行证: 用户 密码 域名空间  下载中心 社区论坛 信息公告 my小屋
联系我们
设为首页
加入收藏

 

qq,asp,php,jsp,xml,sql,.net,编程 程序 网页图象 建站经验 私服
首页 | 新闻资讯 | 编程开发 | 网页设计 | 图形图象 | 网络媒体 | 网站模板 | 数 据 库 | 投稿
论坛 | 操作系统 | 系统优化 | 网络安全 | 黑客技术 | 硬件学堂 | 硬件报价 | 服 务 器 | 地图
专题 | 应用软件 | 聊天通讯 | q q 专栏 | 建站经验 | 在线工具 | 站长club | 注 册 表 | 旧版
社会 | 游戏娱乐 | 设计欣赏 | 疑难解答 | 社区论坛 | 韩国素材 | 素材图库 | 广告服务 | 服务
当前位置:首页>>在线服务>>疑难解答>>正文 新版上线![旧版]
注:打开慢时请稍等

php+sqlserver分页最简单方法

http://www.iyit.net  日期:2006-10-6 15:40:18  来源:iyit.net收集  点击:
参加讨论
听朋友说php+sqlserver分页很麻烦,今天研究了一下,发现其实比php+mysql还简单(实际上mysql也可以这样)。  
下面这个函数就是取出符合纪录的第$page页的纪录到数组:  
function  selectpage($querystr,$page,$pagesize)  
{  
                       $r=@mssql_query($querystr);  
                       if  ($r){  
                                   $totalpage  =  ceil(mssql_num_rows($r)/$pagesize);  
                                   if  (!$page  &brvbar  &brvbar$page<=0)  $page=1;  
                                   if  ($page>$totalpage)  $page=$totalpage;  
                                   $begin  =  (  $page-1  )  *  $pagesize;  
                                   $rearr=array();  
                                   $index=0;  
                                   if($pagesize>0)  mssql_data_seek($r,$begin);  
                                   while($resultarr=@mssql_fetch_array($r)){  
                                               if($pagesize>0)  
                                                           if($index>$pagesize-1)  break;  
                                               $rearr[$index]=$resultarr;                                                                          
                                               $index++;  
                                   }  
                                   return  $rearr;  
                       }else  
                                   return  false;  
}  
 
我觉得这样只用查询一次,用limit还有查询两次。实际上asp就是用这种方式!  
欢迎各位提出意见  
---------------------------------------------------------------  
 
好,鼓励  
---------------------------------------------------------------  
 
<?  
//-----------------------  
//    通用分页控制……  
//  21bird    2002.8.22  
//-----------------------  
//class  pagecontrol  
class  pagecontrol{  
   //properties  
   var  $m_recordamount;  
   var  $m_pageamount;  
   var  $m_currpage  =  1;  
   var  $recordrow_per_apage  =  10;  
   var  $m_nextpage;  
   var  $m_prevpage;  
   var  $m_usingindex;  
   var  $m_startindex;  
   var  $r;  
   //methods  
   function  pagecontrol($r,  $recordamount,  $p)  
   {  
       $this->r  =  $r;  
       if  (($p  ==  "")    &brvbar  &brvbar  (round($p)  ==  0)){  
               $p=1;  
       }  
       $this->m_currpage  =  $p;  
       $this->m_recordamount  =  $recordamount;  
       $this->m_pageamount  =  ceil($this->m_recordamount/$this->recordrow_per_apage);  
       $this->m_startindex  =  ($this->m_currpage  -  1)  *  $this->recordrow_per_apage;  
       $this->m_usingindex  =  $this->m_startindex;  
       //calulate  the  current  page  
       if($this->m_currpage  !=  $this->m_pageamount)  
           $this->m_nextpage  =  $this->m_currpage  +  1;  
       else  
           $this->m_nextpage  =  $this->m_pageamount;  
       if($this->m_currpage  !=  1)  
           $this->m_prevpage  =  $this->m_currpage  -  1;  
       else  
           $this->m_prevpage  =  1;  
   }  
   function  next_record()  
   {  
       if(($this->m_usingindex  !=  $this->m_recordamount  -  1)  &brvbar  &brvbar  
                   ($this->m_usingindex  <  ($this->recordrow_per_apage)))  
       {  
           $this->m_usingindex  ++;  
           $result  =  1;  
       }  
       else  
           $result  =  0;  
       return  $result;  
   }  
   function  link_first()  
   {  
       echo  "<a  href=\""  .  $_server['php_self']  .  "?p=1\">首页</a>";  
   }  
   function  link_last()  
   {  
       echo  "<a  href=\""  .  $_server['php_self']  .  "?p="  .  $this->m_pageamount  .  "\">尾页</a>";  
   }  
   function  link_prev()  
   {  
       echo  "<a  href=\""  .  $_server['php_self']  .  "?p="  .$this->m_prevpage  .  "\">前页</a>";  
   }  
   function  link_next()  
   {  
       echo  "<a  href=\""  .  $_server['php_self']  .  "?p="  .$this->m_nextpage  .  "\">后页</a>";  
   }  
   function  link_any()  
   {  
       echo  "<form  method=get  action=\""  .  $_server['php_self']  .  "\">直接到<input  type=text  name=p  size  =  3>页<input  type=submit  value  =  'go!!!'></form>";  
   }  
   function  getcurrent()  
   {  
       mssql_data_seek($this->r,  $this->m_usingindex);  
       list($result)  =  mssql_fetch_array($this->r);  
       return  $result;  
   }  
}  
?>  
 
凑个热闹^_*  
---------------------------------------------------------------  
 
在mssql的mssql_query($string,$int);  
其中$string可以是sql  server存储过程的调用.这样就要自己写一个类似于limit的存储过程,在sql  server他虽有top这项功能,但它的翻页,我们那时有个写vb的同事封装了一个用游标翻页的存储过程,由于年事以久,且不是自己封装的所一存储过程的代码找不见了,现在说一下调用过程,望能引发大家的一些思维:应该不是误导^_^  
$string="exec  web_scrollpage  'fo03t001','complex,description,isroomreqd,isexcludegrp,isautoassign','complex,description,isroomreqd,isexcludegrp,isautoassign',".$page_rows.",".$addvalue;  
exec  web_scrollpage  'fo03t001',---这一段是掉用存储过程,及所要访问的table  
'complex,description,isroomreqd,isexcludegrp,isautoassign',----要读的字段  
'complex,description,isroomreqd,isexcludegrp,isautoassign',----存储过程中建立临时表所要的字段  
".$page_rows.",".$addvalue-----每页的行数,及开始的位置  
 
在存储过程中是先建临时表,移游标到$addvalue所在的位置,然后移动游标一条条将记录读到临时表里,最后再读一次临时,删掉临时表,就这样是不是很烦.  
不过在读大量数据是用数组翻页就不如这样了^_^

编辑:黑鹰 [发送给好友] [打印本页] [关闭窗口] [返回顶部]
上一篇:我的数据库不能写入,为什么???
下一篇:如何把金额的小数形式翻译成中文形式,比方说1.1¥翻译成壹圆壹角?
转载请注明来源:www.iyit.net
特别声明: 本站除部分特别声明禁止转载的专稿外的其他文章可以自由转载,但请务必注明出处和原始作者。文章版权归文章原始作者所有。对于被本站转载文章的个人和网站,我们表示深深的谢意。如果本站转载的文章有版权问题请联系编辑人员,我们尽快予以更正。

 相关文章
php和asp上传漏洞探究 php作wap开发时遇到的问题  我在windows  xp上安装apache2.044+php
apache+php,怎样打开session支持?? 在linux中怎么配置pdflib和php  高分! 怎么样同时解释.php和.php3的文件呀,急
php 4.1.0 及以后版本使用post变量的接 apache2-win32+php的成功安装方法 我只是想在本地机上学习php ,还要安装
装了php。运行时出现在以下提示 怎么删除mysql??? php在win2003上面怎样安装?
php 在linux 下如何開啟ftp功能 如何屏蔽掉 phpinfo() php.ini中文版
请问怎样降低php的警告等级? 一个打击了我学习php热情的问题:怎么样 php初学者的入门问题
运行php程序会出现乱码是怎么回事?zen 怎么样修改mysql安装后的root空密码? 如何让php拥有root的权限?
为什么php中的函数mail()不能发送邮件 成功地在linux/unix下安装apache+php+o 在win2k下如何安装apache、mysql、php?
最新更新 热点排行 推荐新闻
我在windows  xp上安装apache2.044+ph
apache+php,怎样打开session支持??
在linux中怎么配置pdflib和php  高分!
怎么样同时解释.php和.php3的文件呀,
php 4.1.0 及以后版本使用post变量的接
我的qq被盗走的原因分析
webqq好玩不?大鸟带你一起体验
奇奇怪怪的qq密技十五招
qq被盗到出售过程详解
微软winxp sp3再次跳票 推至08年发布
google苹果合作浏览器 防恶意网站
微软操作系统实现开源?
网管应当如何管理windows操作系统?
让windows xp系统锁定期间拒绝关机
windowsvista中文版11月30日正式发布
我在windows  xp上安装apache2.044+ph
php 在linux 下如何開啟ftp功能
apache2-win32+php的成功安装方法
怎么删除mysql???
apache+php,怎样打开session支持??
合并vcd片断、快速删除文件夹--dos命令
dos教程 dos命令基础应用
破解qq密码如此简单 
低格、分区、高格的应对--dos命令应用
一劳永逸--批处理命令(一)
qq2006 beta3隆重发布 实用功能一一奉
美国微软总部相中重庆15岁网络奇才(图
qq号码激活的常见问题及案例分析 
sql server安装文件挂起错误解决办法
三分钟让你的系统变处女:acronis tru
exeplorer.exe错误的问题的总结、解决
我的qq被盗走的原因分析
webqq好玩不?大鸟带你一起体验
奇奇怪怪的qq密技十五招
qq被盗到出售过程详解
google苹果合作浏览器 防恶意网站
网管应当如何管理windows操作系统?
让windows xp系统锁定期间拒绝关机
windowsvista中文版11月30日正式发布
google优化网站管理员指导方针
hilltop算法- 探索google排名新算法

设置首 页 - 版权声明 - 广告服务 - 关于我们 - 联系我们 - 友情连接
copyrights © 2004-2006 iyit.net all rights reserved.
网站合作、广告联系qq:147007642、466949678
易特网络技术 点击这里给我发消息