Blogger Information
Blog 60
fans 1
comment 1
visits 64419
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template
使用方法重载与call_user_func_array()模拟TP框架的链式查询_2018年9月4日
PHP学习
Original
757 people have browsed it

实例

<?php
/**
 * 定义类数据库查询
 */

class  Query
{
    //保存SQL语句中的各个组成部份
    private $sql = [];
    //数据库连接对象
    private $pdo = null;
    //构造方法:连接数据库
    public function __construct()
    {
        //给一个方法来连接数据库
        $this->pdo = new PDO('mysql:host=127.0.0.1;dbname=php','root','root');
    }
    //tbale()来获取SQL语句的表句
    public function table($table)
    {
        $this->sql['table'] = $table;
        return $this;//返回当前类实例对象,便于链式调用该对象的其它方法
    }
    //fields()来获取查询的字段列表
    public function fields($fields)
    {
        $this->sql['fields'] = $fields;
        return $this;
    }
    //查询的条件
    public function where($where)
    {
        $this->sql['where'] = $where;
        return $this;
    }
    //检查的终极方法//查询具体语句
    public function select()
    {
        $sql = "SELECT {$this->sql['fields']} FROM {$this->sql['table']} WHERE {$this->sql['where']}";
        $stmt = $this->pdo->prepare($sql);
        $stmt->execute();
        return $stmt->fetchAll(PDO::FETCH_ASSOC);
    }
}

运行实例 »

点击 "运行实例" 按钮查看在线实例

调用执行

实例

<?php
/**
 *  使用方法重载与call_user_func_array()模拟TP框架的链式查询
 * 用方法的重载实现方法跨类调用
 */
require 'Query.php';
//Db::tbale()->fields()->where()->select();

//数据库操作的入口类

class Db
{
    public static function __callStatic($name, $arguments)
    {
        //call_user_func_array([类名,方法],[])的使用方法与参数
        return call_user_func_array([(new Query()),$name],$arguments);
    }
}

$result = Db::table('user')->fields('id,name,email,age')->where('id>0')->select();
echo '<pre>';
echo var_export($result);

echo '<hr>';

foreach ($result as $sum)
{
    echo $sum['id'],$sum['name'],$sum['email'],$sum['age'].'<br>';
}
echo count($result);

运行实例 »

点击 "运行实例" 按钮查看在线实例


Correction status:qualified

Teacher's comments:
Statement of this Website
The copyright of this blog article belongs to the blogger. Please specify the address when reprinting! If there is any infringement or violation of the law, please contact admin@php.cn Report processing!
All comments Speak rationally on civilized internet, please comply with News Comment Service Agreement
0 comments
Author's latest blog post