php - PDO 返回不正确但重复的数据。 key 不在数据库中。

标签 php pdo

我刚开始使用 $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)确实存在,数字键则不然。查询为什么返回这些?我该如何防止它们被退回?

最佳答案

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

像这样使用:

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

fetchAll docs
fetch docs

关于php - PDO 返回不正确但重复的数据。 key 不在数据库中。,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39426916/

相关文章:

php - Mysqli 到 PDO 的转换

java - 将数百万条记录从本地插入Godaddy托管

php - Smarty 切割字符串以添加点

PHP MySQL 最接近邮政编码

php - 如何删除 SQL 结果中最旧的条目?

php - PDO::FETCH_ASSOC PDO::FETCH_ARRAY 是什么?

php - 使用 Alamofire Swift 5 上传文件有问题吗?

php - Silverstripe URL 如何工作?

php - PDO 参数读取为字符串而不是 int

php - 我可以隐藏表中具有特定或特殊值(例如零)的数据吗? PHP 和 MySQL