我还在考虑,对于一些复杂的联合查询,可以派生一个类,重新构造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.="没有连接上数据库。<br>"; 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="没有查询的表或没有批定显示多少行或没有查询语句<br>"; } $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.="计算结果集总数目的查询失败,请检查。<br>"; 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());