调用时需要替换值fetchObject
,有一个表(mysql)有一个json类型的列,我想通过fetchObject
json字符串创建对象将其变成数组时,我没有找到解决方案。调用对象本身并对其进行填充是合乎逻辑的,根据需要转换基数中的值。
升级版:
调用 `fetchObject... 时需要实现值替换
@LaukhinAndrey帮助解决了这个问题。但是,下面的问题是相关的
目标对象的属性是私有的,这里我不明白它到底是怎么工作fetchObject
的,因为对象有方法__set
,__clone
而且没有一个工作,问题来了,它如何fetchObject
返回一个带有私有属性的填充类,绕过魔术方法?
升级版:
调用所有方法
class User
{
private ?string $name = null;
private ?string $surname = null;
private ?string $lastname = null;
private ?string $email = null;
private int $phone = 0;
private ?string $address = null;
private $time_register = 0;
private ?string $pass = null;
private $service = '';
function __construct(...$arg)
{
var_dump(__METHOD__);
var_dump($arg);
$this->service = json_decode($this->service, true);
}
function __destruct()
{
var_dump(__METHOD__);
}
function __call($arg1, $arg2)
{
var_dump(__METHOD__);
var_dump($arg1);
var_dump($arg2);
}
static function __callStatic($arg1, $arg2)
{
var_dump(__METHOD__);
var_dump($arg1);
var_dump($arg2);
}
function __get($arg)
{
var_dump(__METHOD__);
var_dump($arg);
}
function __set($arg1, $arg2)
{
var_dump(__METHOD__);
var_dump($arg1);
var_dump($arg2);
}
function __isset($arg)
{
var_dump(__METHOD__);
var_dump($arg);
}
function __unset($arg)
{
var_dump(__METHOD__);
var_dump($arg);
}
function __sleep()
{
var_dump(__METHOD__);
}
function __wakeup()
{
var_dump(__METHOD__);
}
function __serialize()
{
var_dump(__METHOD__);
}
function __unserialize()
{
var_dump(__METHOD__);
}
function __toString()
{
var_dump(__METHOD__);
}
function __invoke()
{
var_dump(__METHOD__);
}
function __set_state()
{
var_dump(__METHOD__);
}
function __clone()
{
var_dump(__METHOD__);
}
}
# ---------------------------------
$PDO = DB::Connect();
$PDOSt = $PDO->query('SELECT * FROM service_users');
var_dump($PDOSt->fetchObject('SCCT\Model\User'));
结果:
string(28) "SCCT\Model\User::__construct"
array(0) {
}
object(SCCT\Model\User)#51 (9) {
["name":"SCCT\Model\User":private]=>
string(4) "Jonh"
["surname":"SCCT\Model\User":private]=>
string(3) "Doe"
["lastname":"SCCT\Model\User":private]=>
NULL
["email":"SCCT\Model\User":private]=>
string(11) "jd@mail.com"
["phone":"SCCT\Model\User":private]=>
int(71000010203)
["address":"SCCT\Model\User":private]=>
NULL
["time_register":"SCCT\Model\User":private]=>
string(19) "2022-05-20 13:36:18"
["pass":"SCCT\Model\User":private]=>
NULL
["service":"SCCT\Model\User":private]=>
array(1) {
["hello"]=>
string(5) "world"
}
}
string(27) "SCCT\Model\User::__destruct"
不管访问修饰符如何,如果属性存在,则赋值,如果不存在,则尝试调用魔法方法
__set
。如果未定义,则将创建该属性。因此我们可以定义
__set
以防止自动创建属性,但永远不会在现有属性上调用它。鉴于属性是私有的,一种解决方案是在传递给的类的构造函数中进行必要的转换
fetchObject
。属性填充对应列的值后会调用构造函数。如果未设置,这是默认顺序PDO::FETCH_PROPS_LATE
。另一种方法是提供一种
prepareProps
在从数据库接收到下一个对象时调用的方法。您可以使用
ReflectionProperty
.