URL パラメーターのデータに基づいて、PDO を使用してクエリを実行したい (はい、これは攻撃を受けやすいことはわかっていますが、ユーティリティの内部コードです)。
$user = 'USER';
$pass = 'PASSWORD';
$dsn = 'mysql:dbname=PRODUCTS;host=HOST';
try {
$productDB = new PDO($dsn, $user, $pass);
$productDB->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
}
catch(PDOException $e) {
$msg = 'PDO ERROR' . $e->getFile() . ' L.' . $e->getLine() . ' : ' . $e->getMessage();
die($msg);
}
if(isset($_GET['cat']))
{
$cat = $_GET['cat'];
print "cat = $cat <br>";
$products = $productDB->prepare('SELECT * FROM products WHERE cat_id LIKE ?');
$products->execute(array($cat));
$rows = $products->rowCount();
print "$rows rows returned";
?>
<table border="1">
<tr>
<td>product_id</td>
<td>product_name</td>
</tr>
<?php
foreach ($products->fetchAll() as $row) {
$id = $row['product_id'];
$product_name = $row['product_name'];
print "<tr>";
print "<th scope=\"row\"><b>$id</b></th>";
print "<td> $product_name </td>";
print "<tr>";
}
print "</table>";
}
?>
このコードを実行すると、クエリに応じて正しい行数が出力されますが、テーブルにはデータが入力されません。
prepare
また、execute
行を次のように置き換えてみました。
$products = $productDB->query("SELECT * FROM products WHERE cat_id LIKE $cat");
これは正しい行数を返しますが、それ以外の場合は役に立ちません。
最後に、 foreach 行を次のようなものに置き換えてみました。
$rows = $products->fetchAll();
foreach ($rows as $row) {
固定クエリで同じことをしようとする試みはすべて正常に機能しますが、変数要素をクエリに配置して結果を反復処理する方法がわかりません。