gpt4 book ai didi

php - 从单个 PDO 数组实例化多个 PHP 对象(无样板)

转载 作者:可可西里 更新时间:2023-10-31 23:31:03 24 4
gpt4 key购买 nike

如果你想从数据库中获取单个对象,PDO 非常有用:

$obj = $handle->fetchAll(PDO::FETCH_CLASS, $obj_name);

如果您希望在一行中返回多个类类型(例如:在执行 JOIN 时),PDO 的用处不大:

$handle->fetchAll(PDO::FETCH_ASSOC);

...followed by some data mapping on the resulting array .很好 - 除了我想出的每一种方法看起来都很糟糕。

我的问题是:当该数组的内容可能反射(reflect)全部、没有、部分或超过上课?

示例:

给定一个 PDO 从数据库返回的数组 $vars = ('a' => 1, 'b' => 2, 'c' => 3, 'x' => 7, 'y' => 8, 'z' => 9),构造对象ABC(需要$a$b$c)XYZ ($x, $y, $z) 没有复制粘贴过多。

选项1

class ABC {
private $a, $b, $c;
function __construct ($a = null, $b = null, $c = null) {
$this->$a = $a ? $a : $this->a;
$this->$b = $b ? $b : $this->b;
...

(大量样板代码/复制粘贴/要求实例化代码已经按正确顺序准备了所有变量)

选项 2

function ABCFactory($vars = array()) {
return new ABC($vars['a'], $vars['b']....

(更好,但如果数组键不存在于 $vars 中会报错。当然,我们可以使用 isset() 但这会使样板文件问题变得更糟)

选项3

foreach ($vars AS $key => $value) {
eval("if (isset(\$key) && \$value) \$this->$key = '$value';");
}

(它有效,整洁,整洁,易于重用,它会反射(reflect)我添加的任何新类变量...但它是 eval(),这让我做噩梦!:] )

解决方案

dockeryZ 对此进行了暗示,但 mleko 提供了答案。我以前没有听说过可变变量,但它们正是我要找的。我终于去了:

$def_vars = get_object_vars($this);
foreach ($vars AS $key => $value) {
if (array_key_exists($key, $def_vars)) $this->{$key}=$value;
}

但是,任何人在将来发现这个问题时都应该牢记 Johan Perez 的回答,并且不要将此片段用作构造函数中的快捷方式......特别是如果输入数组来自用户的GET 或 POST 参数!

最佳答案

给你

<?php
class Name {
public function __construct($data) {
foreach($data as $key=>$val){
$this->{$key}=$val;
}

}
}

关于php - 从单个 PDO 数组实例化多个 PHP 对象(无样板),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23202048/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com