Fetching PDO - $handler vs $stmt?


Fetching PDO - $handler vs $stmt?

我是PHP/PDO的新手,所以请温柔。。。

我正在尝试将代码输入数据库,然后将其提取到网页中。我可以做第一个,但在显示它时遇到了困难。我想知道这是否是因为我试图将$stm和$handler组合在一起?

这是我将信息输入数据库的代码:

try {
    $conn = new PDO("mysql:host=$servername;dbname=$dbname", $username, $password);
    // set the PDO error mode to exception
    $conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
    // prepare sql and bind parameters
    $stmt = $conn->prepare("INSERT INTO survey (storename, receipt, date_visit)
    VALUES (:storename, :receipt, :date_visit)");
    $stmt->bindParam(':storename', $storename);
    $stmt->bindParam(':receipt', $receipt);
    $stmt->bindParam(':date_visit', $date_visit);
    // insert a row
    $storename = $_POST['storename'];
    $receipt = $_POST['receipt'];
    $date_visit = $_POST['date_visit'];
}
catch(PDOException $e)
{
    echo "Error: " . $e->getMessage();
}
$conn = null;

它工作得很好。

这是我从数据库中获取信息的代码。

<?php
try {
    $handler = new PDO('mysql:host=localhost;dbname=test', 'test', 'test');
    $handler->setAttribute(PDO::ATRR_ERRMODE, PDO::ERRMODE_EXCEPTION);
} catch(PDOException $e) {
    echo $e->getMessage();
    die();
  }
class SurveyEntry {
    public $id, $storename, $receipt, $date_visited,
        $entry;
    public function __construct() {
        $this->entry = "{$this->storename} posted: {$this->receipt}";
    }
}
$query = $handler->query('SELECT * FROM survey');
$query->setFetchMode(PDO::FETCH_CLASS, 'SurveyEntry');
while($r = $query->fetch()) {
    echo $r->entry, '<br>';
}
?>

我可以确认它连接正确,但我无法让它显示任何信息。我想知道这是否与我使用的$stmt和$handler的差异有关?我一直在网上学习教程,很可能把两个教程混合在一起,试图实现我想要的目标。

更新:

我通过更新我从数据库中调用的方式来让它工作起来:

$host = "localhost";
$dbname = "test";
$user = "test";
$password = "test";
$handler = new PDO( "mysql:dbname=$dbname;host=$host" , $user , $password );

弄清楚了-我用了"R_ERRMODE"而不是"ATTR_ERRMODE(打字错误)"

你好吗?

你应该尝试修复它:

1-两种不同的连接:

$conn = new PDO("mysql:host=$servername;dbname=$dbname", $username, $password);

$handler = new PDO('mysql:host=localhost;dbname=test', 'test', 'test');