我刚开始使用 $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_id
、user_id
、meta_key
、meta_value
)确实存在,数字键则不然。查询为什么返回这些?我该如何防止它们被退回?
最佳答案
它不是重复的,它只是您当前使用的FETCH_MODE
。要获取关联键,您只需要指定;默认情况下,它会同时获取。
像这样使用:
$query->fetchAll(PDO::FETCH_NUM); // to fetch with numeric indexes
$query->fetchAll(PDO::FETCH_ASSOC); // to fetch with associative indexes
关于php - PDO 返回不正确但重复的数据。 key 不在数据库中。,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39426916/