首頁 後端開發 php教程 php中一个可查询全部表的“通用”查询分页类

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

Jun 13, 2016 am 10:54 AM
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.="
登入後複製
"; while([email protected]_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()是将查询结果集存在一个二维数组里,本例中没有用到。 */ ?>?

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

華為GT3 Pro和GT4的差異是什麼? 華為GT3 Pro和GT4的差異是什麼? Dec 29, 2023 pm 02:27 PM

許多用戶在選擇智慧型手錶的時候都會選擇的華為的品牌,其中華為GT3pro和GT4都是非常熱門的選擇,不少用戶都很好奇華為GT3pro和GT4有什麼區別,下面就給大家介紹一下二者。華為GT3pro和GT4有什麼差別一、外觀GT4:46mm和41mm,材質是玻璃鏡板+不鏽鋼機身+高分纖維後殼。 GT3pro:46.6mm和42.9mm,材質是藍寶石玻璃鏡+鈦金屬機身/陶瓷機身+陶瓷後殼二、健康GT4:採用最新的華為Truseen5.5+演算法,結果會更加的精準。 GT3pro:多了ECG心電圖和血管及安

修復:截圖工具在 Windows 11 中不起作用 修復:截圖工具在 Windows 11 中不起作用 Aug 24, 2023 am 09:48 AM

為什麼截圖工具在Windows11上不起作用了解問題的根本原因有助於找到正確的解決方案。以下是截圖工具可能無法正常工作的主要原因:對焦助手已開啟:這可以防止截圖工具開啟。應用程式損壞:如果截圖工具在啟動時崩潰,則可能已損壞。過時的圖形驅動程式:不相容的驅動程式可能會幹擾截圖工具。來自其他應用程式的干擾:其他正在運行的應用程式可能與截圖工具衝突。憑證已過期:升級過程中的錯誤可能會導致此issu簡單的解決方案這些適合大多數用戶,不需要任何特殊的技術知識。 1.更新視窗與Microsoft應用程式商店應用程

五個精選的Go語言開源項目,帶你探索科技世界 五個精選的Go語言開源項目,帶你探索科技世界 Jan 30, 2024 am 09:08 AM

在現今科技快速發展的時代,程式語言也如雨後春筍般湧現。其中一門備受矚目的語言就是Go語言,它以其簡潔、高效、並發安全等特性受到了許多開發者的喜愛。 Go語言以其強大的生態系統而著稱,其中有許多優秀的開源專案。本文將介紹五個精選的Go語言開源項目,帶領讀者一起探索Go語言開源專案的世界。 KubernetesKubernetes是一個開源的容器編排引擎,用於自

Laravel開發:如何使用Laravel Echo和Pusher實現WebSockets通訊? Laravel開發:如何使用Laravel Echo和Pusher實現WebSockets通訊? Jun 13, 2023 pm 05:01 PM

Laravel是一個流行的PHP框架,具有高度可擴展性和高效性,它提供了許多強大的工具和程式庫,讓開發者可以快速建立高品質的網路應用程式。其中,LaravelEcho和Pusher是兩個非常重要的工具,透過它們可以輕鬆實現WebSockets通信,本文將詳細介紹如何在Laravel應用程式中使用這兩個工具。什麼是WebSockets? WebSockets

Go語言開發必備:5個熱門框架推薦 Go語言開發必備:5個熱門框架推薦 Mar 24, 2024 pm 01:15 PM

《Go語言開發必備:5個熱門框架推薦》Go語言作為一門快速、高效的程式語言,受到越來越多開發者的青睞。為了提高開發效率,優化程式碼結構,許多開發者選擇使用框架來快速建立應用。在Go語言的世界中,有許多優秀的框架可供選擇。本文將介紹5個熱門的Go語言框架,並提供具體的程式碼範例,幫助讀者更好地理解和使用這些框架。 1.GinGin是一個輕量級的Web框架,擁有快速

PHP中echo關鍵字的作用與使用方法詳解 PHP中echo關鍵字的作用與使用方法詳解 Jun 28, 2023 pm 08:12 PM

PHP中echo關鍵字的作用和使用方法詳解PHP是一種廣泛使用的伺服器端腳本語言,它在網頁開發中被廣泛應用。而echo關鍵字是在PHP中用來輸出內容的一種方法。本文將詳細介紹echo關鍵字的作用與使用方法。作用:echo關鍵字的主要作用是將內容輸出到瀏覽器。在網頁開發中,我們需要將資料動態地呈現到前端頁面上,這時就可以使用echo關鍵字將資料輸出到頁面上。 e

市面上最流行的golang框架有哪些? 市面上最流行的golang框架有哪些? Jun 01, 2024 pm 08:05 PM

目前最受歡迎的Go框架有:Gin:輕量級、高效能的Web框架,簡潔易用。 Echo:快速、高度可自訂的網路框架,提供高效能路由和中介軟體。 GorillaMux:快速、靈活的多工器,提供進階路由設定選項。 Fiber:效能最佳化的高效能Web框架,處理高並發請求。 Martini:物件導向設計的模組化網路框架,提供豐富的功能集。

如何修復無法連線到iPhone上的App Store錯誤 如何修復無法連線到iPhone上的App Store錯誤 Jul 29, 2023 am 08:22 AM

第1部分:初始故障排除步驟檢查蘋果的系統狀態:在深入研究複雜的解決方案之前,讓我們先從基礎知識開始。問題可能不在於您的設備;蘋果的伺服器可能會關閉。造訪Apple的系統狀態頁面,查看AppStore是否正常運作。如果有問題,您所能做的就是等待Apple修復它。檢查您的網路連接:確保您擁有穩定的網路連接,因為「無法連接到AppStore」問題有時可歸因於連接不良。嘗試在Wi-Fi和行動數據之間切換或重置網路設定(「常規」>「重置」>「重置網路設定」>設定)。更新您的iOS版本:

See all articles