3

请看代码,数组包含表的表字段名

class User {
    public $db_fields = array('id', 'username', 'password', 'first_name', 'last_name');

    public $id;
    public $username;
    public $password;
    public $first_name;
    public $last_name;

}

这个想法是用一个函数删除公共变量,以便它自动从我可以访问的数组中创建公共变量---

例子

我想删除

public $id;
public $username;
public $password;
public $first_name;
public $last_name;

部分,并希望它由$db_fields数组自动生成。

这样我就可以通过

$user = new User();
$user->username = "Ismail";

我所做的是

extract($db_fields);

但它给出了一个错误:

解析错误:语法错误,意外的 T_VARIABLE,在第 3 行的 C:\xampp\htdocs\advphp\dbclass\extractex.php 中需要 T_FUNCTION

4

3 回答 3

1

您可以一起删除$db_fields所有内容并依赖于 SQL 查询返回的列,如下所示:

class User
{
    private $_data;
    public function __construct($id = null) {
        //TODO: Load data into $this->_data for user of $id
    }

    public function __get($name) {
        if (array_key_exists($name, $this->_data))
            return $this->_data[$name];

        return NULL;
    }

    public function __set($name, $value) {
        $this->_data[$name] = $value;
    }

    public function UpdateUser(){
        //TODO: update the database with any changes to the user data or do an insert for new user
    }
}

然后您可以动态获取/设置属性,而无需像这样首先声明它们:

$newUser = new User();
$newUser->username = "Ismail";
$newUser->UpdateUser();
于 2012-12-15T08:15:33.587 回答
1

不幸的是,如果您尝试使用extract($db_fields);它需要从构造函数或函数之类的方法内部运行的方法,那么您的想法将不起作用。extract($db_fields);它会为你提取变量,但它们不会公开它们将是该函数的本地变量,例如,如果你尝试这个

function __construct(){
    extract($db_fields);
    // the $id will be available in the constructor only
    // it will get disposed when this method finished executing
}

另一种方法是使用属性或 setter 和 getter 方法

<?php
class User {
    private $db_fields = array(
                        'id', 
                        'username', 
                        'password' => 'ismailPassword', 
                        'first_name',
                        'last_name'
      );

    function getValue($key){
       if (array_key_exists($key, $this->db_fields)){
            return $this->db_fields[$key];
       }
       return NULL;
    }

    function setValue($key, $value){
        $this->db_fields[$key] = $value;        
    }
}

$user = new User();
$user->setValue('username', 'Ismail');
echo " Username: ";
echo $user->getValue('username');
echo "\n\n Password: ";
echo $user->getValue('password');
?>

你可以在这里测试代码http://codepad.org/8MwBwdut

于 2012-12-15T09:14:49.350 回答
0

如果您的数据库结果返回键值对,您可以这样做:

$array = array();
while (($r = $result->fetch_array()) != false){
   $obj = new \stdClass();
   foreach($r as $key => $value){
       $obj->$key = $value;
   }
   $array[] = $obj;
}
于 2012-12-15T07:51:18.423 回答