php 传递类名,php – PDO :: FETCH_CLASS,不传递类名作为参数

我遇到了一段代码,其中调用了PDO :: FETCH_CLASS而没有将类的名称作为参数传递,如下所示:

function getUsers() {

$DBH = $this->getDbh();

$query = "SELECT * FROM users";

try {

$STH = $DBH->query($query);

$users = $STH->fetchAll(PDO::FETCH_CLASS);

} catch(PDOException $e) {

}

return $users;

}

If fetch_style includes PDO::FETCH_CLASSTYPE (e.g. PDO::FETCH_CLASS | PDO::FETCH_CLASSTYPE) then the name of the class is determined from a value of the first column.

所以我不确定我究竟是什么意思,也不知道它是如何运作的.

假设我有一个记录的用户表

> id:1

>姓名:乔希

>等等……

那么PDO :: FETCH_CLASS怎么能知道什么是类名呢?我可以用类名称在列表中添加列,FETCH_CLASS会从数据库中获取类名吗?记录结构的例子将受到高度赞赏…… thx

*我正在测试这个类而不是作者,所以更改类是无关紧要的

解决方法:

对于fetchAll方法,如果未提供classname且未引发PDO :: FETCH_CLASSTYPE标志,则返回stdClass对象(就像使用PDO :: FETCH_OBJ一样).这就是发生的事情(lxr):

1436 switch(how & ~PDO_FETCH_FLAGS) {

1437 case PDO_FETCH_CLASS:

1438 switch(ZEND_NUM_ARGS()) {

1439 case 0:

1440 case 1:

1441 stmt->fetch.cls.ce = zend_standard_class_def;

1442 break

然后,在do_fetch中,由于没有提供类名,因此该值保持不变.这是有道理的,因为stdClass有时被认为是一种匿名类. )

这解释了你必须处理的代码; @ eggyal的答案解释了如何使用PDO :: FETCH_CLASS || PDO :: FETCH_CLASSTYPE组合.它实际上是一种非常强大的技术,允许您跳过工厂方法中的样板开关.

标签:php,mysql,pdo

来源: https://codeday.me/bug/20190727/1557685.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值