-4

我在谷歌和其他几个网站上进行了查看,但我无法弄清楚为什么这不起作用。

我正在处理 uni 作业,并运行以下代码:

$db = connect();
$testname = 'chunk';
 try {
        $stmt = $db->prepare('SELECT * FROM TreasureHunt.Player WHERE name = ?');
        $stmt->execute(array($testname));
        $result = $stmt->fetchAll(PDO::FETCH_ASSOC);
        $stmt->closeCursor();
        } 
    catch (PDOException $e) { 
    print "Error checking login: " . $e->getMessage(); 
}

$count = $stmt->rowCount();
echo 'Row count: ', $count, '<br>';
var_dump($result);
echo '<br>Result: ', $result['name'], ' pw: ', $result["password"], '<br>';
print_r($result);

但是,这会导致以下错误:

Notice: Undefined index: name in /.automount/net/ufiler2/u2/cs3/dbes2376/lib/html/th/index.php on line 30

现在我知道这意味着,在我的 $result 变量中,索引“名称”必须不存在。但这让我感到困惑,因为它确实存在,通过查看: var_dump($result) var_dump($result) 给了我:

array(1) { [0]=> array(5) { ["name"]=> string(5) "chunk" ["password"]=> string(7) "truffle" ["pw_salt"]=> string(8) "g#m#g#m#" ["gender"]=> string(1) "m" ["addr"]=> string(10) "Goon Docks" } } 

和 print_r($result) 给我:

Array ( [0] => Array ( [name] => chunk [password] => truffle [pw_salt] => g#m#g#m# [gender] => m [addr] => Goon Docks ) )

那么为什么我不能将它们称为 $result['name'] 呢?或者我实际上如何引用它?

谢谢。对不起,如果这是一个基本问题。

4

4 回答 4

3

你应该使用$result[0]['name'];

于 2013-05-27T13:07:06.410 回答
2

fetchAll()返回一个数组数组。所以在你的情况下访问

$result[0]['name']

代替

$result['name']

另一种选择是使用只是fetch()为了每次只获得一行结果。

于 2013-05-27T13:07:58.430 回答
0

您的代码中有几个错误。我已经重写了它,希望能删除它们,并让它按预期工作:

$db = connect();
$testname = 'chunk';

try {
    $stmt = $db->prepare('SELECT * FROM TreasureHunt.Player WHERE name = ?');
    $stmt->execute(array($testname));

    foreach($stmt->fetchAll(PDO::FETCH_ASSOC) as $row){
        echo 'Result: ' . $result['name'] . ' pw: ' . $result['password'] . '<br />';
    }
} catch (PDOException $e) { 
    print "Error checking login: " . $e->getMessage(); 
}

$count = $stmt->rowCount();
echo 'Row count: ' . $count .  '<br>';
于 2013-05-27T13:14:41.627 回答
0

您的代码中有几个错误。我已经重写了它,希望能删除它们,并让它按预期工作。您还必须按照标签 wiki中的说明进行连接

$db = connect();
$testname = 'chunk';
$stmt = $db->prepare('SELECT * FROM TreasureHunt.Player WHERE name = ?');
$stmt->execute(array($testname));
$row = $stmt->fetch();

$count = $stmt->rowCount();
echo 'Row count: ', $count, '<br>';
echo '<br>Result: ', $row['name'], ' pw: ', $row["password"], '<br>';
于 2013-05-27T13:26:57.467 回答