php中一个可查询全部表的“通用”查询分页类
php中一个可查询所有表的“通用”查询分页类
一个可查询所有表的“通用”查询分页类?
最近突发奇想,希望写出一个可以针对所有表的查询分页类。因为在实际的开发中,恐怕查询并将结果集分页显示是用得最多的代码,而表的结构是多样的,我想尽可能地提高代码的重用率和维护性。?
以下是我写的,请各位加以指点,测试,看能否进行更好的改进和更多的支持。?
目前还只支持单一的表,不支持联合查询。但未来可以会考虑如何支持。?
代码:?<?php /**************************************************************** 这个类主要是解决针对很多表的简单数据查询,还在完善中。希望广大网友多提意见和建议。 我的目的是开发出一个几乎可以适用于所有mysql表的查询并将结果集分页的类。 可以自动识别查询中要显示的字段值。 在此,特别声明,要感谢chinaunix的朋友,特别是PHP版的网友们长期以来给我的帮助。 特别要提的是NightKids,一直以来,他都给了我无私的帮助,甚至是他的源代码。 这个类可以被任何人自由引用,使用,修改。但请保留这段文字。 使用这个类造成的一切损失,都与作者tonera无关。 我还在考虑,对于一些复杂的联合查询,可以派生一个类,重新构造sql实现。 这个类没有考虑更多的显示风格,你可以自己构造。 *****************************************************************/ class browser{ var $c_table; //要查询的表名 var $c_rows; //要显示的行数 var $c_lation; //查询的条件 var $c_order; //排序的条件 var $c_result; //查询的数据连接句柄 var $c_query; //最终构造的查询 var $c_found; //结果集 var $c_error; //错误收集器 var $c_offset; //分页显示的偏移量 var $total; //结果集的总数 //连接数据库 function connect(){ include '../connect.inc.php'; if ($connection==false){ $this->c_error.="没有连接上数据库。"; exit; } $this->c_result=$connection; } //构造函数,初始化变量 function browser($tablename,$row,$sql,$lation,$orderby){ $this->c_table=$tablename; $this->c_rows=$row; if(empty($this->c_offset)){ $this->c_offset=0; } if (empty($tablename) or empty($row) or empty($sql)){ $this->c_error="没有查询的表或没有批定显示多少行或没有查询语句"; } $this->c_query=$sql; if (!empty($lation)){ $this->c_query.=" ".$lation; } if (!empty($orderby)){ $this->c_query.=" ".$orderby; } } //计算总页数 function TatolPage(){ $sult=mysql_query("select count(*) as 'total_rows' from $this->c_table",$this->c_result); if ($sult==false) { $this->c_error.="计算结果集总数目的查询失败,请检查。"; exit; } $tempvar=mysql_fetch_array($sult); $this->total=$tempvar[0]; } //查询得到结果集,存入数组c_found[][]中 function GetFound(){ $sult=mysql_query($this->c_query,$this->c_result) or die(mysql_error()); while ($found=mysql_fetch_array($sult)){ $this->c_found[]=$found; } } //查询数据,并将结果分页存入一个变量 function ShowTable(){ $this->connect(); $this->TatolPage(); if (empty($_GET[offset])){ $_GET[offset]=0; } $this->c_query.=" limit ".$_GET[offset].", ".$this->c_rows; $sult=mysql_query($this->c_query,$this->c_result) or die(mysql_error()); //解析query,得到要显示出来的字段值 $tempvar=explode(" ",$this->c_query); $fields=explode(",",$tempvar[1]); //字段值(数组) //显示数据到一个表 $echo_content.="
"; while([email protected]_fetch_array($sult)){ $echo_content.="
"; return $echo_content; } } /*例子 //browser("表名",每页显示的数目,"sql","查询条件","排序条件"); $gggg=new browser("news",5,"select auto_id,news_title from news","","order by newstime desc"); $temp=$gggg->ShowTable(); echo $temp; //$gggg->GetFound()是将查询结果集存在一个二维数组里,本例中没有用到。 */ ?>?
"; } //分页 if ($this->c_rows==0){ $this->c_error.="每页显示的数目不能为0"; exit; } $total_page=ceil($this->total/$this->c_rows); $pre_page=$_GET[offset]-$this->c_rows; //下一页 $nex_page=$_GET[offset]+$this->c_rows; //显示上一页 if ($pre_page>=0){ $echo_content.=""; $echo_content.="".$found[1]."
"; //显示用户指定的字段,此处需仔细看 for($i=2;$i
上页&"; }else{ $echo_content.=" "; }else{ $echo_content.="&下页"; } $echo_content.="上页&"; } //显示页码 for($i=1;$ic_rows==($i-1)){ $echo_content.="&第".$i."页&"; }else{ $echo_content.="&c_rows.">".$i."&"; } } //显示下一页 if ($nex_page!=0 and ($_GET[offset]+$this->c_rows)total){ $echo_content.="&下页

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

许多用户在选择智能手表的时候都会选择的华为的品牌,其中华为GT3pro和GT4都是非常热门的选择,不少用户都很好奇华为GT3pro和GT4有什么区别,下面就就给大家介绍一下二者。华为GT3pro和GT4有什么区别一、外观GT4:46mm和41mm,材质是玻璃表镜+不锈钢机身+高分纤维后壳。GT3pro:46.6mm和42.9mm,材质是蓝宝石玻璃表镜+钛金属机身/陶瓷机身+陶瓷后壳二、健康GT4:采用最新的华为Truseen5.5+算法,结果会更加的精准。GT3pro:多了ECG心电图和血管及安

为什么截图工具在Windows11上不起作用了解问题的根本原因有助于找到正确的解决方案。以下是截图工具可能无法正常工作的主要原因:对焦助手已打开:这可以防止截图工具打开。应用程序损坏:如果截图工具在启动时崩溃,则可能已损坏。过时的图形驱动程序:不兼容的驱动程序可能会干扰截图工具。来自其他应用程序的干扰:其他正在运行的应用程序可能与截图工具冲突。证书已过期:升级过程中的错误可能会导致此issu简单的解决方案这些适合大多数用户,不需要任何特殊的技术知识。1.更新窗口和Microsoft应用商店应用程

在当今科技快速发展的时代,编程语言也如雨后春笋般涌现出来。其中一门备受瞩目的语言就是Go语言,它以其简洁、高效、并发安全等特性受到了许多开发者的喜爱。Go语言以其强大的生态系统而著称,其中有许多优秀的开源项目。本文将介绍五个精选的Go语言开源项目,带领读者一起探索Go语言开源项目的世界。KubernetesKubernetes是一个开源的容器编排引擎,用于自

《Go语言开发必备:5个热门框架推荐》Go语言作为一门快速、高效的编程语言,受到越来越多开发者的青睐。为了提高开发效率,优化代码结构,很多开发者选择使用框架来快速搭建应用。在Go语言的世界中,有许多优秀的框架可供选择。本文将介绍5个热门的Go语言框架,并提供具体的代码示例,帮助读者更好地理解和使用这些框架。1.GinGin是一个轻量级的Web框架,拥有快速

Laravel是一个流行的PHP框架,具有高度可扩展性和高效性,它提供了很多强大的工具和库,让开发者可以快速构建高质量的Web应用程序。其中,LaravelEcho和Pusher是两个非常重要的工具,通过它们可以很容易地实现WebSockets通信,本文将详细介绍如何在Laravel应用程序中使用这两个工具。什么是WebSockets?WebSockets

PHP中echo关键字的作用和使用方法详解PHP是一种广泛使用的服务器端脚本语言,它在网页开发中被广泛应用。而echo关键字是在PHP中用于输出内容的一种方法。本文将详细介绍echo关键字的作用和使用方法。作用:echo关键字的主要作用是将内容输出到浏览器。在网页开发中,我们需要将数据动态地呈现到前端页面上,这时就可以使用echo关键字将数据输出到页面上。e

第1部分:初始故障排除步骤检查苹果的系统状态:在深入研究复杂的解决方案之前,让我们从基础知识开始。问题可能不在于您的设备;苹果的服务器可能会关闭。访问Apple的系统状态页面,查看AppStore是否正常工作。如果有问题,您所能做的就是等待Apple修复它。检查您的互联网连接:确保您拥有稳定的互联网连接,因为“无法连接到AppStore”问题有时可归因于连接不良。尝试在Wi-Fi和移动数据之间切换或重置网络设置(“常规”>“重置”>“重置网络设置”>设置)。更新您的iOS版本:

目前最流行的Go框架有:Gin:轻量级、高性能的Web框架,简洁易用。Echo:快速、高度可定制的Web框架,提供高性能路由和中间件。GorillaMux:快速、灵活的多路复用器,提供高级路由配置选项。Fiber:性能优化的高性能Web框架,处理高并发请求。Martini:面向对象设计的模块化Web框架,提供丰富的功能集。
