RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1412050
Accepted
Jarry Roxwell
Jarry Roxwell
Asked:2022-07-20 22:55:35 +0000 UTC2022-07-20 22:55:35 +0000 UTC 2022-07-20 22:55:35 +0000 UTC

PDO fetchObject 的工作原理是什么

  • 772

调用时需要替换值fetchObject,有一个表(mysql)有一个json类型的列,我想通过fetchObjectjson字符串创建对象将其变成数组时,我没有找到解决方案。调用对象本身并对其进行填充是合乎逻辑的,根据需要转换基数中的值。

升级版:

调用 `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"
php
  • 1 1 个回答
  • 29 Views

1 个回答

  • Voted
  1. Best Answer
    Laukhin Andrey
    2022-07-21T01:26:18Z2022-07-21T01:26:18Z

    不管访问修饰符如何,如果属性存在,则赋值,如果不存在,则尝试调用魔法方法__set。如果未定义,则将创建该属性。

    因此我们可以定义__set以防止自动创建属性,但永远不会在现有属性上调用它。

    鉴于属性是私有的,一种解决方案是在传递给的类的构造函数中进行必要的转换fetchObject。属性填充对应列的值后会调用构造函数。如果未设置,这是默认顺序PDO::FETCH_PROPS_LATE。

    另一种方法是提供一种prepareProps在从数据库接收到下一个对象时调用的方法。

    您可以使用ReflectionProperty.

    • 1

相关问题

  • mysqli 类的对象无法转换为字符串

  • 您的系统中缺少 ext-http *,您的系统中缺少 ext-mysql_xdevapi *

  • 如何从csv中删除bom?

  • 当我按下 Enter 键时,如何让 PhpStorm 的 Emmet 插件触发,就像 VS Code 一样?

  • 注释在 Symfony5 中不起作用

  • 搜索最近的地理位置点

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    我看不懂措辞

    • 1 个回答
  • Marko Smith

    请求的模块“del”不提供名为“default”的导出

    • 3 个回答
  • Marko Smith

    "!+tab" 在 HTML 的 vs 代码中不起作用

    • 5 个回答
  • Marko Smith

    我正在尝试解决“猜词”的问题。Python

    • 2 个回答
  • Marko Smith

    可以使用哪些命令将当前指针移动到指定的提交而不更改工作目录中的文件?

    • 1 个回答
  • Marko Smith

    Python解析野莓

    • 1 个回答
  • Marko Smith

    问题:“警告:检查最新版本的 pip 时出错。”

    • 2 个回答
  • Marko Smith

    帮助编写一个用值填充变量的循环。解决这个问题

    • 2 个回答
  • Marko Smith

    尽管依赖数组为空,但在渲染上调用了 2 次 useEffect

    • 2 个回答
  • Marko Smith

    数据不通过 Telegram.WebApp.sendData 发送

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5