我想根据 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
andexecute
行替换为:
$products = $productDB->query("SELECT * FROM products WHERE cat_id LIKE $cat");
它返回正确的行数,但没有其他帮助。
最后,我尝试将 foreach 行替换为:
$rows = $products->fetchAll();
foreach ($rows as $row) {
我尝试对固定查询执行相同操作都可以正常工作,但是我无法弄清楚如何在查询中放置变量元素,然后遍历结果。