php - 使用 PDO 将数组值作为对象属性
问题描述
我想将数组值存储为对象属性。我正在关注 mysqli 的示例,但我想改用 PDO。
我有一个用户类:
class User {
public $id;
public $username;
public $password;
public $first_name;
public $last_name;
public static function find_all_users(){
global $database;
$result_set = $database->query($sql);
return $result_set;
} //end method
} //end User class
我已使用以下数据库类连接到我的数据库。注意:常量 DB_SERVER 等在别处定义并包含在文件中
class Database{
public $connection;
function __construct(){
$this->open_db_connection();
}//end of constructor
public function open_db_connection(){
try{
$this->connection = new PDO('mysql:host='. DB_SERVER .';dbname='. DB_NAME, DB_USER, DB_PASSWORD);
$this->connection->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
}catch(PDOException $e){
echo 'Server Error: ' . $e->getCode(;
}//end catch block
}//end of method
public function query($sql){
$stmt = $this->connection->prepare($sql);
$stmt->execute();
$result = $stmt->fetchAll(PDO::FETCH_ASSOC);
return $result;
} //end query method
$database = new Database();
我想从 User 类创建一个对象并使用该类的属性来访问我的数据。
$user = new User();
$user->id = $result_set['id'];
$user->username = $result_set['username'];
$user->password = $result_set['password'];
$user->first_name = $result_set['first_name'];
$user->last_name = $result_set['last_name'];
echo $user->id;
在 mysqli 中,这将通过放置以下内容来完成:
public static function find_all_users(){
global $database;
$result_set = $database->query($sql);
mysqli_fetch_array($result_set);
return $result_set;
} //end method
我得到的错误是“未定义的索引:id”“未定义的索引:用户名”“未定义的索引:密码”“未定义的索引:first_name”“未定义的索引:last_name”
我认为我的错误来自 fetchAll(PDO::FETCH_ASSOC)。我应该从我的 echo 语句中得到一个值。回声 $user->id;
什么是与 PDO 的 mysqli_fetch_array 类似的更好的 fetch 方法?
下面是我 print_r $result_set 的时候:
解决方案
fetchAll()
返回一个二维数组。您需要遍历元素:
$all_users = array();
foreach ($result_set as $result) {
$user = new User();
$user->id = $result['id'];
$user->username = $result['username'];
$user->password = $result['password'];
$user->first_name = $result['first_name'];
$user->last_name = $result['last_name'];
$all_users[] = $user;
echo $user->id;
}
推荐阅读
- javascript - 它的 MIME 类型(“application/json”)不是有效的 JavaScript MIME 类型
- c# - 如何使用委托参数模拟泛型方法
- c# - 设置 Android.Support.V4.App.Fragments 时出错
- android - 当应用程序需要互联网才能运行时,在没有互联网的情况下发送短信和通知?
- javascript - 模式弹出窗口中的完整日历事件信息
- html - 如何在html中的另一个页面上使用表单的提交按钮
- ios - ios - 与 twitter 分享图片
- java - 我如何告诉 Hibernate 在 selfjoin @OneToOne 中忽略“0”
- n1ql - 使用索引调整以下查询
- jquery - 当侧边栏可见时,Swiper 无法正确调整图像大小