15

我是使用 $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)确实存在,数字键不存在。查询如何返回这些?以及如何防止它们被退回?

4

3 回答 3

25

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

像这样使用:

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

fetchAll docs
获取文档

于 2013-04-29T09:14:34.187 回答
11

这不是重复数据fetchAll返回数值数组和关联数组中的数据。

查看文档

使用它只检索关联数组

return $query->fetchAll(PDO::FETCH_ASSOC);
于 2013-04-29T09:13:12.383 回答
-1

似乎对我有用。把这个放在上面

use Illuminate\Database\Events\StatementPrepared;

何时获取包括 pdo::fetch_assoc

return($pdo->fetchAll(\PDO::FETCH_ASSOC));
于 2018-11-14T03:01:40.950 回答