1. 编程: 使用方法重载与call_user_func_array()模拟TP框架的链式查询:
实例
<?php //Db::table('think_user')->field('id,name,email')->where('id',1)->select(); require 'query.php'; class Db { public static function __callStatic($name, $arguments) { return call_user_func_array([new Query(),$name],$arguments); } } $result = Db::table('name') ->field('id,name,age') ->where('age > 0') ->select(); echo '<pre>'; print_r($result); class Query { //SELECT 字段列表 FROM 表名 WHERE 条件 private $sql = []; private $pdo = null; public function __construct() { $this->pdo = new PDO('mysql:host=127.0.0.1;dbname=user','root','root'); } //获取sql语句中的表名 public function table($table) { $this->sql['table'] = $table; //返回实例对象; return $this; } public function field($field) { $this->sql['field'] = $field; //返回实例对象; return $this; } public function where($where) { $this->sql['where'] = $where; //返回实例对象; return $this; } public function select () { //拼接查询语句 $sql = "SELECT {$this->sql['field']} FROM {$this->sql['table']} WHERE {$this->sql['where']}"; $stmt = $this->pdo->prepare($sql); $stmt->execute(); return $stmt->fetchAll(PDO::FETCH_ASSOC); } }
运行实例 »
点击 "运行实例" 按钮查看在线实例
2. 问答: 后期静态绑定的原理与使用场景分析:
后期静态绑定工作原理是存储了在上一个“非转发调用”(non-forwarding call)的类名。当进行静态方法调用时,该类名即为明确指定的那个(通常在 :: 运算符左侧部分);当进行非静态方法调用时,即为该对象所属的类
一般用于什么场景:最常见的一般用于查询语句