我确信这一定是一个简单的答案,但我只是没有看到它。为了简化我的所有其余代码,我正在尝试将所有数据库代码移动到一个类中。
我遇到了这个错误,我不明白为什么
致命错误:在第 18 行的 /var/www/php/dbclass.php 中不在对象上下文中时使用 $this(我用箭头标记了第 18 行)
这是我的课
<?php
class kdb {
var $dbhost = "localhost";
var $dbname = "name";
var $dbuser = "root";
var $dbpass = "pass";
var $error;
// function __construct($persons_name) {
// $this->name = $persons_name;
// }
//function to insert safely
public static function exe($qry_string, $var_array) {
$host = $this->dbhost; <------------------ LINE 18
$name = $this->dbname;
$user = $this->dbuser;
$pass = $this->dbpass;
$retries = 30;
while ($retries > 0) {
try {
$pdo_conn = new PDO("mysql:host={$host};dbname={$name}", $user, $pass);
$retries = 0;
//echo 'run query';
} catch (PDOException $e) {
$retries--;
sleep(1); // Wait 1s between retries.
log::enter_log("Error connecting: {$retries} retries left");
}
}
$q = $pdo_conn->prepare($qry_string);
$q->execute($var_array);
$return_arr = $q->fetchAll();
$this->error = $q->errorInfo();
//dbconn::logquery($qry_string, $var_array, $q->rowCount(), $error[2]);
return $return_arr;
}
}
?>
和页面上的代码
$db = new kdb();
$db_list = $db->exe('select * from table where id = ?', array(42));
var_dump($db_list);
请注意它只完成了一半,我知道目前它比它需要的更复杂。