PDO 返回不正确但重复的数据。密钥不在数据库中。

2022-08-31 00:29:30

我是使用$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


答案 1

它不是重复的,它只是你正在使用的当前。要获取关联键,只需要您指定这样;默认情况下,它同时获取两者。FETCH_MODE

像这样使用:

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

获取所有文档
获取文档


答案 2

这不是重复的数据返回数字数组以及关联数组中的数据。fetchAll

查看文档

使用它仅检索关联数组

return $query->fetchAll(PDO::FETCH_ASSOC);

推荐