php - 使用 PDO 进行 MySQL 搜索查询并显示结果列表

标签 php mysql search pdo

如标题所示,我正在尝试使用 PDO 和 MySQL 显示搜索结果列表...我有一个食谱表,其中包含食谱 ID、名称和描述。我想要一个搜索框,它可以在名称或描述中找到关键字,即“沙拉”或“胡萝卜”,并通过仅显示它们的名称来返回所有匹配食谱的列表。在我改用 PDO 之前,我有以下代码,它们完全满足了我的需要:

<?php
include ("dbconnect.php");

if (!isset($_POST['search']))    {
    header("Location:index.php");
}

$search_sql="SELECT * FROM Recipe WHERE name LIKE '%".$_POST['search']."%' OR description LIKE '%".$_POST['search']."%'";
$search_query=mysql_query($search_sql);
if (mysql_num_rows($search_query)!=0) {
    $search_rs=mysql_fetch_assoc($search_query); }
?>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title>Untitled Document</title>
</head>
<body>
<h3>Search results</h3>
<?php
if (mysql_num_rows($search_query)!=0) {
    do { ?>
        <p><?php echo $search_rs['name']; ?></p>
    <?php }
    while ($search_rs=mysql_fetch_assoc($search_query));
}
else {
    echo "No results found";
}
?>
</body>
</html>

但是,我在使用 PDO 做同样的事情时遇到了困难......到目前为止我已经提出了以下代码,但我怀疑我做错了而且我不知道如何显示实际结果...... .如果有人能提供一些帮助,我将不胜感激,请原谅我对此事的了解不足,我还是个新手。

        <?php
include ("dbconnect.php");

if (!isset($_POST['search']))    {
    header("Location:index.php");
}

// keep track post values
$name = "%".$_POST['search']."%";
$description = "%".$_POST['search']."%";

$pdo = Database::connect();
$pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
$sql ='SELECT * FROM recipe WHERE name LIKE ? OR description LIKE ?';
$q = $pdo->prepare($sql);
$q->execute(array($name,$description));
$data = $q->fetchAll(PDO::FETCH_ASSOC);
Database::disconnect();
?>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
    <meta charset="utf-8">
    <link   href="css/bootstrap.min.css" rel="stylesheet">
    <script src="js/bootstrap.min.js"></script>
    <title>Untitled Document</title>
</head>
<body>
<div class="container">
    <div class="row">
        <table class="table table-striped table-bordered">
            <thead>
                 <tr>
                    <th>Search Results</th>
                 </tr>
            </thead>
            <tbody>
    <?php
    if ($data != null) {
        foreach($data as $row)
             {
                 echo '<tr>';
                 echo '<td>'. $row['name'] . '</td>';
                 echo '</tr>';
             }
        }else
             {
                 echo '<td>'. "No results found" .'</td>';
             }?>
            </tbody>
        </table>
    </div>
</div>
</body>
</html>

最佳答案

您需要将 % 放在您的参数上:

 // keep track post values
 $name = "%".$_POST['search']."%";
 $description = "%".$_POST['search']."%";

请注意,这通常会执行得很糟糕,因为以 % 开头的 like 会杀死您在 namedescription 上的任何索引>。随着数据的增长,您将开始看到速度放缓。

相反,您可以查看全文搜索选项:http://blog.marceloaltmann.com/en-using-the-mysql-fulltext-index-search-pt-utilizando-mysql-fulltext/

关于php - 使用 PDO 进行 MySQL 搜索查询并显示结果列表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23573841/

相关文章:

php - PHP邮件功能无法完成电子邮件的发送

javascript - 如何创建一周内可点击的小时网格,并将点击保存到 MySQL?

jquery - 数据表 - 数据表外的搜索框

php - 模型参数设置最佳实践?

php - 使用 phpspec 进行测试 - 来自当前类的模拟方法

php - 检查特定行是否存在mysql

mysql - 插入从锁定行中获取的值的问题

mysql - delphi mysql 查询结果

mysql - 在 PHP 中检索 MySQL 全文搜索的匹配上下文(和安全性)

mysql - 前缀匹配 MySQL 索引 : LIKE word% vs. MATCH 'word*' 用于搜索结果自动完成