澄清一行/ s - >将sql数据设置为对象变量

时间:2016-12-16 10:51:54

标签: php mysql oop object user-object

这是我在这里的第一个问题,我将尽可能地澄清它。

我是一个初学者,我正在通过lynda - 当我到达这个部分时,超越PHP MySQL课程。

代码工作得很好,我只需要更好地解释自己对代码中注释的行。

require_once('database.php');

class User {

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

  public static function find_all() {
    return self::find_by_sql("SELECT * FROM users");
  }

    /////

    public static function find_by_sql($sql="") {

    global $database;
  $result_set = $database->query($sql);
  $user_array = array();
  while ($row = $database->fetch_array($result_set)) {
    $user_array[] = self::instantiate($row);
    }
    return $user_array;
  }

我最近明白的最后几行:)

private static function instantiate($row) {
    $user = new self; 

    foreach($row as $attribute=>$value){ 
      if($user->has_attribute($attribute)) { 
        $user->$attribute = $value;          /// THIS LINE BUGS ME
      }
    }
    return $user;

  }

  private function has_attribute($attribute) {

    $user_vars = get_object_vars($this); 
    return array_key_exists($attribute, $user_vars);
  }
}

所以我认为我不理解array_key_exists返回TRUE或FALSE,在我的情况下是真的,但是$users->$attributes =$value ;行对我没有意义,

因此,我检查来自对象

的fetch数组MATCH变量名的键
if($user->has_attribute($attribute)) { //and then this is true,perform nxt line
    $user->$attribute = $value;      // i got match of attribute above,how does it put values in $user_vars???

我知道它说“如果用户具有与该获取数组中的键相同的属性然后放入该属性$ value的相同属性值,但我只是看不到当我从未返回对象变量时它是如何完成的

感谢您的时间!

编辑: 类变量名称等于数据库

中column_names的名称

2 个答案:

答案 0 :(得分:0)

将此行更改为

//        $user->$attribute = $value; 
       $user->{$attribute} = $value; 

我希望这会起作用

答案 1 :(得分:0)

User类包含公共属性$id$username$password等。这意味着您可以按以下格式为属性指定值:

$u = new User;
$u->id = 123;
$u->username = 'username';

并使用动态属性名称:

$prop = 'id';
$u->$prop = 123;

$prop = 'username';
$u->$prop = 'username';

这就是您不理解的行中发生的事情:

if ($user->has_attribute($attribute)) {
    $user->$attribute = $value;

has_attribute方法使用$user函数获取get_object_vars对象的所有属性。后者将对象属性作为数组提取:

$user_vars = get_object_vars($this);
/* i.e.
$user_vars = array (
  'id' => ...,
  'username' => ...,
  ...
);
*/

然后has_attribute方法检查属性数组中是否存在给定的$attribute键:

return array_key_exists($attribute, $user_vars);

如果存在(true),$attribute属性将分配给$value