我有一个定义了选择、插入、更新和删除方法的 DatabaseObject 类。该类的目的是将我的 MySQL 数据库中的行子集表示为 PHP 对象。构造函数调用 MySQL 的 SELECT 命令,而析构函数调用 DELETE 命令(除非我要求它不要这样做)。
这是我的 DatabaseObject 类:
class DatabaseObject {
protected $table;
protected $index_field;
private $data;
function __construct($id) {
//MySQL SELECT and assign resource to data
}
function __destruct() {
//MySQL UPDATE
}
public function insert($data) {
global $db; //Database Class for using MySQL
$fields = array();
$values = array();
foreach ($data as $field => $value) {
$fields[] = "`".$field."`";
$values[] = "'".$db->escape($value)."'";
}
$sql = "INSERT INTO ".$this->table." (".join(', ', $fields).") VALUES (".join(', ', $values).")";
if($db->query($sql)) {
return $db->insertID();
} else {
return false;
}
}
//More methods; update(), delete(), select()
}
当我想访问特定表时,我扩展了 DatabaseObject 类。例如,我的 User 类用于我的用户表。这里是:
class User extends Object {
public static $anonymous_data = array('user_id' => 0, 'user_level' => ANONYMOUS, 'username' => 'Anonymous');
function __construct($user_id = NULL) {
global $db;
$this->db = $db;
$this->table = USER_TABLE;
$this->index_field = 'user_id';
parent::__construct($user_id);
}
function __destruct() {
parent::__destruct();
}
//Other user methods; login(), logout() etc.
}
现在,我希望能够从用户类调用插入方法,而无需实例化用户类。我很确定,我必须让它静态才能这样做。如何使插入方法静态,但仍允许它使用扩展类中定义的表?
换句话说,我希望能够做到这一点:
User::insert($data); //INSERT into user table
AnotherClass::insert($data); //INSERT into another table
...没有实例化任何一个类。