PDO Fetch语句仅检索第一列

问题描述 投票:-25回答:1

正如标题所述,我只能抓住id列,而其他列却收到未定义的索引错误。

我的代码:

if(isset($_SESSION['id'])) {
    $presh = $_SESSION['id'];
    $stmt = $pdo->prepare("SELECT id FROM users WHERE id = :id");
    $id = $presh;
    $stmt->execute(array(':id'=>$id));
    $accountinfo = $stmt->fetch(PDO::FETCH_ASSOC);
}

稍后在我的代码中,我这样引用它:

Karma <span id="kcurrent"><?php echo $accountinfo["karmacurrent"]; ?></span> | <span id="ktotal"><?php echo $accountinfo["karmatotal"]; ?></span>

行确实存在并且已被填充,我在做​​什么错?

php mysql pdo
1个回答
6
投票

您只能选择id列,因为这就是查询中的全部。

尝试这样的事情

if (isset($_SESSION['id'])) {
    $presh = $_SESSION['id'];
    $stmt = $pdo->prepare("SELECT id, karmacurrent FROM users WHERE id = :id");

    $id = $presh;

    $stmt->execute(
        array(
            ':id'=>$id
        )
    );

    $accountinfo = $stmt->fetch(PDO::FETCH_ASSOC);
}

基本上,您只从表而不是其他列中检索ID

© www.soinside.com 2019 - 2024. All rights reserved.