Home Backend Development PHP Tutorial php中一个可查询全部表的“通用”查询分页类

php中一个可查询全部表的“通用”查询分页类

Jun 13, 2016 pm 01:06 PM
content echo gt offset this

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.="
Copy after login
"; while($found=@mysql_fetch_array($sult)){ $echo_content.=""; //显示用户指定的字段,此处需仔细看 for($i=2;$i".$found[$i].""; } $echo_content.=""; } //分页 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.=""; }else{ $echo_content.="&下页"; } $echo_content.="
"; $echo_content.="".$found[1]."
上页&"; }else{ $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.="&下页
"; 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()是将查询结果集存在一个二维数组里,本例中没有用到。 */ ?> ?

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: How To Get Giant Seeds
1 months ago By 尊渡假赌尊渡假赌尊渡假赌
Two Point Museum: All Exhibits And Where To Find Them
1 months ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

What are the differences between Huawei GT3 Pro and GT4? What are the differences between Huawei GT3 Pro and GT4? Dec 29, 2023 pm 02:27 PM

Many users will choose the Huawei brand when choosing smart watches. Among them, Huawei GT3pro and GT4 are very popular choices. Many users are curious about the difference between Huawei GT3pro and GT4. Let’s introduce the two to you. . What are the differences between Huawei GT3pro and GT4? 1. Appearance GT4: 46mm and 41mm, the material is glass mirror + stainless steel body + high-resolution fiber back shell. GT3pro: 46.6mm and 42.9mm, the material is sapphire glass + titanium body/ceramic body + ceramic back shell 2. Healthy GT4: Using the latest Huawei Truseen5.5+ algorithm, the results will be more accurate. GT3pro: Added ECG electrocardiogram and blood vessel and safety

Fix: Snipping tool not working in Windows 11 Fix: Snipping tool not working in Windows 11 Aug 24, 2023 am 09:48 AM

Why Snipping Tool Not Working on Windows 11 Understanding the root cause of the problem can help find the right solution. Here are the top reasons why the Snipping Tool might not be working properly: Focus Assistant is On: This prevents the Snipping Tool from opening. Corrupted application: If the snipping tool crashes on launch, it might be corrupted. Outdated graphics drivers: Incompatible drivers may interfere with the snipping tool. Interference from other applications: Other running applications may conflict with the Snipping Tool. Certificate has expired: An error during the upgrade process may cause this issu simple solution. These are suitable for most users and do not require any special technical knowledge. 1. Update Windows and Microsoft Store apps

Five selected Go language open source projects to take you to explore the technology world Five selected Go language open source projects to take you to explore the technology world Jan 30, 2024 am 09:08 AM

In today's era of rapid technological development, programming languages ​​are springing up like mushrooms after a rain. One of the languages ​​that has attracted much attention is the Go language, which is loved by many developers for its simplicity, efficiency, concurrency safety and other features. The Go language is known for its strong ecosystem with many excellent open source projects. This article will introduce five selected Go language open source projects and lead readers to explore the world of Go language open source projects. KubernetesKubernetes is an open source container orchestration engine for automated

Go language development essentials: 5 popular framework recommendations Go language development essentials: 5 popular framework recommendations Mar 24, 2024 pm 01:15 PM

&quot;Go Language Development Essentials: 5 Popular Framework Recommendations&quot; As a fast and efficient programming language, Go language is favored by more and more developers. In order to improve development efficiency and optimize code structure, many developers choose to use frameworks to quickly build applications. In the world of Go language, there are many excellent frameworks to choose from. This article will introduce 5 popular Go language frameworks and provide specific code examples to help readers better understand and use these frameworks. 1.GinGin is a lightweight web framework with fast

How to Fix Can't Connect to App Store Error on iPhone How to Fix Can't Connect to App Store Error on iPhone Jul 29, 2023 am 08:22 AM

Part 1: Initial Troubleshooting Steps Checking Apple’s System Status: Before delving into complex solutions, let’s start with the basics. The problem may not lie with your device; Apple's servers may be down. Visit Apple's System Status page to see if the AppStore is working properly. If there's a problem, all you can do is wait for Apple to fix it. Check your internet connection: Make sure you have a stable internet connection as the "Unable to connect to AppStore" issue can sometimes be attributed to a poor connection. Try switching between Wi-Fi and mobile data or resetting network settings (General > Reset > Reset Network Settings > Settings). Update your iOS version:

Implementing distributed task scheduling using Golang's web framework Echo framework Implementing distributed task scheduling using Golang's web framework Echo framework Jun 24, 2023 am 11:49 AM

With the development of the Internet and the advancement of information technology, the era of big data has arrived, and fields such as data analysis and machine learning have also been widely used. In these fields, task scheduling is an inevitable problem. How to achieve efficient task scheduling is crucial to improving efficiency. In this article, we will introduce how to use Golang's web framework Echo framework to implement distributed task scheduling. 1. Introduction to the Echo framework Echo is a high-performance, scalable, lightweight GoWeb framework. It is based on HTTP

php提交表单通过后,弹出的对话框怎样在当前页弹出,该如何解决 php提交表单通过后,弹出的对话框怎样在当前页弹出,该如何解决 Jun 13, 2016 am 10:23 AM

php提交表单通过后,弹出的对话框怎样在当前页弹出php提交表单通过后,弹出的对话框怎样在当前页弹出而不是在空白页弹出?想实现这样的效果:而不是空白页弹出:------解决方案--------------------如果你的验证用PHP在后端,那么就用Ajax;仅供参考:HTML code

Laravel development: How to implement WebSockets communication using Laravel Echo and Pusher? Laravel development: How to implement WebSockets communication using Laravel Echo and Pusher? Jun 13, 2023 pm 05:01 PM

Laravel is a popular PHP framework that is highly scalable and efficient. It provides many powerful tools and libraries that allow developers to quickly build high-quality web applications. Among them, LaravelEcho and Pusher are two very important tools through which WebSockets communication can be easily implemented. This article will detail how to use these two tools in Laravel applications. What are WebSockets? WebSockets

See all articles