跨類調用后,找不到方法
問題描述
做靜態方法重載實現數據庫的鏈式訪問的練習
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);}
問題解答
回答1:找到問題了,是Query.php的第65行,做拼接的時候,FROM前后應該加上空格。
回答2:頁面提示方法 'table' 在 Database 中未找到
相關文章:
