方人胥 2021-06-12 20:10 采纳率: 100%
浏览 23
已采纳

PHP跨类调用后,找不到方法

做静态方法重载实现数据库的链式访问的练习

demo5.php引用了Query.php的类

然后访问Query中的方法,页面提示我方法 'table' 在 Database 中未找到

以下是源代码,希望可以帮我检查出错误

第一个是Query.php

<?php
 
//常用的数据查询操作
 
class Query
 
{
 
    //连接对象
 
    public $pdo = null;
 
 
 
    //数据表名称
 
    public $table = '';
 
 
 
    //字段列表
 
    public $field = '';
 
 
 
    //查询条件
 
    public $where = '';
 
 
 
    //显示数量
 
    public $limit = 0;
 
 
 
 
 
    //构造方法
 
    public function __construct(PDO $pdo)
 
    {
 
        $this->pdo = $pdo;
 
    }
 
 
 
    //调用表名
 
    public function table($tableName)
 
    {
 
        $this->table = $tableName;
 
        //关键是这一步
 
        return $this;
 
    }
 
 
 
    //调用字段
 
    public function field($fields)
 
    {
 
        $this->field = $fields;
 
        //关键是这一步
 
        return $this;
 
    }
 
 
 
    //设置查询条件
 
    public function where($where)
 
    {
 
        $this->where = $where;
 
        return $this;
 
    }
 
    //设置显示数量
 
    public function limit($limit)
 
    {
 
        $this->limit = $limit;
 
        return $this;
 
    }
 
 
 
    //创建SQL语句查询
 
    public function select()
 
    {
 
        //设置查询条件
 
        $fields = empty($this->field) ? '*' : $this->field;
 
        $where = empty($this->where) ? '' : ' WHERE ' . $this->where;
 
        $limit = empty($this->limit) ? '' : ' LIMIT ' . $this->limit;
 
 
 
        //SQL
 
        $sql = 'SELECT '.$fields. 'FROM' .$this->table. $where . $limit;
 
 
 
        //预处理执行
 
        $stmt = $this->pdo->prepare($sql);
 
        $stmt->execute();
 
        return $stmt->fetchAll(PDO::FETCH_ASSOC);
 
    }
 
}

第二个是demo5.php

<?php
 
//方法重载实例演示
 
require 'Query.php';
 
class Database
 
{
 
    //数据库连接对象
 
    protected static $pdo = null;
 
 
 
    //数据库连接方法,每次查询时再连接,实现真正的惰性连接,节省系统开销
 
    public static function connection()
 
    {
 
        self::$pdo = new PDO('mysql:host=127.0.0.1;dbname=php','root','admin');
 
    }
 
 
 
    //静态方法的重载,实现跨类调用
 
    public static function __callStatic($name,$arguments)
 
    {
 
        //连接上数据库
 
        self::connection();
 
 
 
        //实例化查询类
 
        $query = new Query(self::$pdo);
 
 
 
        //访问Query中的方法
 
        return call_user_func_array([$query, $name],[$arguments[0]]);
 
    }
 
 
 
 
 
}
 
 
 
$cats = Database::table('category')
 
    ->field('cate_id, name, alias')
 
    ->where('cate_id>=2')
 
    ->select();
 
 
 
foreach($cats as $cat){
 
    print_r($cat);
 
}

页面提示方法 'table' 在 Database 中未找到

image.png

  • 写回答

3条回答 默认 最新

  • 关注

    把SQL语句打印出来看看,是不是表名写错了。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 请问一下这个运行结果是怎么来的
  • ¥15 这个复选框什么作用?
  • ¥15 单通道放大电路的工作原理
  • ¥30 YOLO检测微调结果p为1
  • ¥20 求快手直播间榜单匿名采集ID用户名简单能学会的
  • ¥15 DS18B20内部ADC模数转换器
  • ¥15 做个有关计算的小程序
  • ¥15 MPI读取tif文件无法正常给各进程分配路径
  • ¥15 如何用MATLAB实现以下三个公式(有相互嵌套)
  • ¥30 关于#算法#的问题:运用EViews第九版本进行一系列计量经济学的时间数列数据回归分析预测问题 求各位帮我解答一下