私はあらゆる種類のものを検索し、検索し、試してきましたが、これを正しく機能させることができません。誰かが私が間違っていることを見ることができますか? 私はPDOに非常に慣れていないので、他の多くのことでそれを理解しようとしています。
値をバインドしようとする代わりに手動で値を送信した場合、次のように動作させることができますが、プレースホルダーを使用したいです。'Array' の値を取得しました。MySQL が :name で応答し、無効な構文が発生することがあります... bind の値を再配置しようとしましたが、値を返すことができません。これの挿入部分があり、正常に動作しますが、こことクエリ自体を台無しにしています。
あなたが私を助けることができる方向に感謝します。これは私を夢中にさせています:
注: これは単なるテストであるため、db に含まれるすべての列は name 列と phone 列です (これらの障害を乗り越えると拡張されます)。
<?php
# VARs
$host = "MYHOST";
$db = "MYDB";
$user = "MYUSER";
$pw = "MYPW";
# pdo options/attributes
$opts = array( PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION );
# data source name
$dsn = "mysql:host=" . $host . ";dbname=" . $db;
?>
<!DOCTYPE html>
<html>
<head><title>Test</title>
</head>
<body>
<h3>Test</h3>
<p>Pull data using PDO</p>
<form method="POST" action="test.php"><input type="text" name="name"><input type="submit" value="Search"></form><br /><br />
<hr />
<?
try {
$DBH = new PDO($dsn, $user, $pw, $opts);
# $DBH->setAttribute( PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION );
$STH = $DBH->query('SELECT name, phone FROM directory WHERE name LIKE :name');
$STH->bindParam(':name', $_POST['name']);
$STH->setFetchMode(PDO::FETCH_ASSOC);
while($row = $STH->fetch()) {
echo $row['name'] . "\n" . $row['phone'] . "<br />";
}
}
catch(PDOException $e) {
echo "I'm sorry, Dave. I'm afraid I can't do that.<br />";
echo $e->getMessage();
# file_put_contents('PDOErrors.txt', $e->getMessage(), FILE_APPEND);
}
?>
<hr />
</body>
</html>
- - - - - - - - - - - - - 解決済みの回答 - - - - - - - - - - - -
- - - - - - - - - - - - - 解決済みの回答 - - - - - - - - - - - -
以下の回答のおかげで、これが私のクエリと pdo レイアウトの修正です。
<?
try {
$DBH = new PDO($dsn, $user, $pw, $opts);
# $DBH->setAttribute( PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION );
####-------Changed query to prepare
$STH = $DBH->prepare('SELECT name, phone FROM directory WHERE name LIKE :name');
####-------using bindValue instead of bindParam
####-------also using % for wildcards to help with LIKE query (would only give specific search back without)
$STH->bindValue(':name', '%' . $_POST['name'] . '%');
####-------was missing execute (had query above instead of prepare)
$STH->execute();
$STH->setFetchMode(PDO::FETCH_ASSOC);
while($row = $STH->fetch()) {
echo $row['name'] . "\n" . $row['phone'] . "<br />";
}
}
catch(PDOException $e) {
echo "I'm sorry, Dave. I'm afraid I can't do that.<br />";
echo $e->getMessage();
# file_put_contents('PDOErrors.txt', $e->getMessage(), FILE_APPEND);
}
?>