3

我有一个定义了选择、插入、更新和删除方法的 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

...没有实例化任何一个类。

4

1 回答 1

0
<?php
class Foo {
    public static $anonymous_data = array();

    public static function aStaticMethod() {
        self::$anonymous_data = array(key, value);

        foreach (self::$anonymous_data as $key => $value) {
             echo "$key => $value";
        }
    }
}

Foo::aStaticMethod();
$classname = 'Foo';
$classname::aStaticMethod(); // As of PHP 5.3.0
?>

对于静态方法。但是请注意静态变量不能以这种方式访问​​。在此处阅读有关此示例和静态关键字的更多信息:PHP.net

更新:使用self而不是$this->示例。

于 2012-11-14T17:24:45.093 回答