实例
<?php /** * 使用方法重载与call_user_func_array()模拟TP框架的链式查询 */ //Db::table()->fields()->where->select(); require'Query.php'; //数据库操作入口 class Db { public static function __callStatic($name, $arguments) { //call_user_func_array([类名, 方法],[]) //call_user_func_array([对象, 方法],[]) return call_user_func_array([(new Query()),$name],$arguments); } } $result=Db::table('staff') ->fields('id,name,age,salary') ->where('salary>2000') ->select(); //print_r ($result); //用表格将查询结果格式化输出 $table.='<table border="1" cellpadding="5" cellspacing="0"width="60%",align="center">'; $table.='<caption style="font-size: 1.5rem;margin:15px;">员工信息表</caption>'; $table.='<tr bgcolor="#90ee90"><th>ID</th><th>姓名</th><th>年龄</th></tr>'; foreach($result as $staff) { $table.= '<tr align="center">'; $table.= '<td>'.$staff['id'].'</td>'; $table.= '<td>'.$staff['name'].'</td>'; $table.= '<td>'.$staff['age'].'</td>'; $table.= '<td>'.$staff['salary'].'</td>'; $table.='</tr>'; } $table.='</table>'; $num='<p style="text-align: center">共计:<span style="color:red">'.count($result).'</span>条记录 </p>'; echo $table, $num;
运行实例 »
点击 "运行实例" 按钮查看在线实例
query.php
实例
<?php /** * 数据库查询类 */ class Query { // 保存sql语句中的各个组成部分 // SELECT 字段列表 FROM 表名 WHERE 条件 private $sql=[]; //数据库的连接对象 private $pdo=null; //构造方法:连接数据库 public function __construct() { //连接数据库并返回pdo对象 $this->pdo=new PDO('mysql_host=127.0.0.1;dbname=php','root','root'); } //table()获取sql语句的表名 public function table($table) { $this->sql['table']=$table; return $this;//返回当前类实例对象,便于链式调用该对象的其它方法 } //fields()获取sql语句的字段列表 public function fields($field) { $this->sql['fields']=$fields; return $this; } //where()获取sql语句的查询条件 public function where($where) { $this->sql['where']=$where; return $this; } 执行查询,是一个终极方法 public function select($select) { //拼装SELECT查询语句 $sql="SELECT {$this->sql['fields']}FROM{ $this->sql['table']=$table}{ $this->sql['where']}"; $stmt=$this->pdo->prepare($sql); $stmt->execute(); return $stmt->fetchAll(PDO::FECTH_ASSOC); } }
运行实例 »
点击 "运行实例" 按钮查看在线实例