当前位置:首页 > PHP

php实现搜索检索实现

2026-01-30 01:26:54PHP

PHP 实现搜索检索功能

基础数据库查询搜索

使用 SQL 的 LIKE 语句实现简单搜索功能,适用于小型网站或基础需求。

$searchTerm = $_GET['search_term'];
$query = "SELECT * FROM products WHERE name LIKE '%$searchTerm%' OR description LIKE '%$searchTerm%'";
$result = mysqli_query($connection, $query);

使用预处理语句防止 SQL 注入

为了安全性,应该使用预处理语句来处理用户输入。

$searchTerm = $_GET['search_term'];
$stmt = $connection->prepare("SELECT * FROM products WHERE name LIKE ? OR description LIKE ?");
$searchParam = "%$searchTerm%";
$stmt->bind_param("ss", $searchParam, $searchParam);
$stmt->execute();
$result = $stmt->get_result();

全文索引搜索

对于更高效的搜索,可以在 MySQL 表中创建全文索引。

$searchTerm = $_GET['search_term'];
$query = "SELECT * FROM products WHERE MATCH(name, description) AGAINST(? IN BOOLEAN MODE)";
$stmt = $connection->prepare($query);
$stmt->bind_param("s", $searchTerm);
$stmt->execute();
$result = $stmt->get_result();

使用 Elasticsearch 实现高级搜索

对于大型应用,集成 Elasticsearch 能提供更强大的搜索功能。

require 'vendor/autoload.php';
$client = Elasticsearch\ClientBuilder::create()->build();

$params = [
    'index' => 'products',
    'body' => [
        'query' => [
            'multi_match' => [
                'query' => $_GET['search_term'],
                'fields' => ['name^3', 'description']
            ]
        ]
    ]
];

$response = $client->search($params);

实现分页功能

在搜索结果较多时,添加分页功能提升用户体验。

$page = isset($_GET['page']) ? (int)$_GET['page'] : 1;
$perPage = 10;
$offset = ($page - 1) * $perPage;

$query = "SELECT * FROM products WHERE name LIKE ? LIMIT $perPage OFFSET $offset";
$stmt = $connection->prepare($query);
$searchParam = "%$searchTerm%";
$stmt->bind_param("s", $searchParam);
$stmt->execute();
$result = $stmt->get_result();

搜索结果高亮显示

在返回结果中高亮显示匹配的关键词。

function highlightKeywords($text, $keyword) {
    return preg_replace("/(" . preg_quote($keyword, '/') . ")/i", "<span class='highlight'>$1</span>", $text);
}

while ($row = $result->fetch_assoc()) {
    echo highlightKeywords($row['name'], $searchTerm);
    echo highlightKeywords($row['description'], $searchTerm);
}

实现自动补全功能

使用 AJAX 实现搜索框自动补全功能。

// autocomplete.php
$term = $_GET['term'];
$query = "SELECT name FROM products WHERE name LIKE ? LIMIT 5";
$stmt = $connection->prepare($query);
$searchParam = "$term%";
$stmt->bind_param("s", $searchParam);
$stmt->execute();
$result = $stmt->get_result();

$suggestions = [];
while ($row = $result->fetch_assoc()) {
    $suggestions[] = $row['name'];
}

echo json_encode($suggestions);

搜索日志记录

记录用户搜索行为以便分析。

$searchTerm = $_GET['search_term'];
$ip = $_SERVER['REMOTE_ADDR'];
$timestamp = date('Y-m-d H:i:s');

$stmt = $connection->prepare("INSERT INTO search_logs (term, ip_address, created_at) VALUES (?, ?, ?)");
$stmt->bind_param("sss", $searchTerm, $ip, $timestamp);
$stmt->execute();

多条件筛选搜索

实现结合多个条件的复合搜索功能。

$conditions = [];
$params = [];
$types = "";

if (!empty($_GET['search_term'])) {
    $conditions[] = "name LIKE ?";
    $params[] = "%" . $_GET['search_term'] . "%";
    $types .= "s";
}

if (!empty($_GET['category'])) {
    $conditions[] = "category_id = ?";
    $params[] = $_GET['category'];
    $types .= "i";
}

$query = "SELECT * FROM products";
if (!empty($conditions)) {
    $query .= " WHERE " . implode(" AND ", $conditions);
}

$stmt = $connection->prepare($query);
if (!empty($params)) {
    $stmt->bind_param($types, ...$params);
}
$stmt->execute();
$result = $stmt->get_result();

这些方法涵盖了从基础到高级的 PHP 搜索实现方案,可以根据项目需求选择合适的实现方式。对于小型项目,简单的数据库查询即可满足需求;对于大型项目,建议考虑使用专门的搜索引擎如 Elasticsearch。

php实现搜索检索实现

标签: php
分享给朋友:

相关文章

php实现分页

php实现分页

PHP实现分页的基本方法 使用LIMIT和OFFSET进行数据库查询分页。通过计算当前页码和每页显示数量,动态生成SQL语句。 $page = isset($_GET['page']) ? (in…

php实现文件上传

php实现文件上传

PHP 文件上传实现方法 在 PHP 中实现文件上传需要处理 HTML 表单和服务器端脚本。以下是详细步骤: 创建 HTML 表单 使用 enctype="multipart/form-data"…

php实现购物车

php实现购物车

PHP实现购物车功能 购物车功能是电商网站的核心模块之一,通常涉及商品添加、删除、数量修改和结算等操作。以下是使用PHP实现购物车功能的几种方法。 使用Session存储购物车数据 Session…

php实现递归

php实现递归

递归的基本概念 递归是一种函数调用自身的技术,适用于解决可以分解为相同子问题的问题。在PHP中,递归需要明确的终止条件(基线条件),否则会导致无限循环。 递归实现阶乘 阶乘是经典的递归案例,n!…

git php实现

git php实现

Git 与 PHP 的集成实现 使用 PHP 执行 Git 命令 通过 PHP 的 exec()、shell_exec() 或 passthru() 函数可以直接调用 Git 命令,适用于服务器端操作…

php实现定时任务

php实现定时任务

PHP 实现定时任务的几种方法 在 PHP 中实现定时任务可以通过多种方式完成,具体选择取决于项目需求和服务器环境。以下是常见的实现方法: 使用 Cron 任务 Cron 是 Linux 系统中常用…