微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

PDO返回错误但重复的数据密钥不在数据库中

如何解决PDO返回错误但重复的数据密钥不在数据库中

它不是重复的,只是FETCH_MODE您所使用的当前。要仅获取关联密钥,您需要这样指定:认情况下,两者都获取

像这样使用:

$query->fetchAll(PDO::FETCH_NUM); // to fetch with numeric indexes
$query->fetchAll(PDO::FETCH_ASSOC); // to fetch with associative indexes

fetchAll文档fetch文档

解决方法

我是使用$ pdo语句的新手,所以可能很简单,我尚未在php.net上阅读。查询数据库时收到重复的结果。

结果:

[0] => Array
    (
        [umeta_id] => 31
        [0] => 31
        [user_id] => 2
        [1] => 2
        [meta_key] => fbmeta
        [2] => fbmeta
        [meta_value] => someMetaValueStuff;
        [3] => someMetaValueStuff;
    )

查询非常简单:

function getData(){
    global $pdo;
    $query = $pdo->prepare('SELECT * FROM usermeta WHERE meta_key = "fbmeta" LIMIT 0,30');
    $query->execute();

    return $query->fetchAll();
}

print_r( getData() );

问题是,在命名的键(umeta_iduser_idmeta_keymeta_value)确实存在,数字键没有。查询如何返回这些?以及如何防止他们被退回?

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。