首页 > 解决方案 > 如果我们实现自定义搜索而不是默认搜索,是否会覆盖 Elasticpress 搜索?

问题描述

问题

我们实现了此代码段,以便在 WP 上仅针对标题而不是默认标题进行自定义搜索。

function __search_by_title_only( $search, $wp_query )
{
    global $wpdb;
    if(empty($search)) {
        return $search; // skip processing - no search term in query
    }
    $q = $wp_query->query_vars;
    $n = !empty($q['exact']) ? '' : '%';
    $search =
    $searchand = '';
    foreach ((array)$q['search_terms'] as $term) {
        $term = esc_sql($wpdb->esc_like($term));
        $search .= "{$searchand}($wpdb->posts.post_title LIKE '{$n}{$term}{$n}')";
        $searchand = ' AND ';
    }
    if (!empty($search)) {
        $search = " AND ({$search}) ";
        if (!is_user_logged_in())
            $search .= " AND ($wpdb->posts.post_password = '') ";
    }
    return $search;
}
add_filter('posts_search', '__search_by_title_only', 500, 2);

我们遇到的问题是,我们认为在搜索任何单词时没有调用 ElasticSearch 服务器,因此(我们认为)正在调用数据库。

重现步骤

  1. 1.- 访问 zocalo.com
  2. 2.- 点击右侧的放大镜图标
  3. 3.- 输入任何单词:“pegasus”是个好词
  4. 4.- 您将获得一些带有缩略图的结果(可能少于 30 个),但显示需要很长时间。(超过 4-5 秒)。
  5. 5.- 如果输入一个新词(墨西哥),返回结果需要超过 34 秒。
  6. 6.- 请不要介意下面显示的附加列表。那是使用另一个插件。

预期行为

我们正在寻求优化对数据库的查询时间,因为我们有大约 200 万条记录,我们需要真正快速地从搜索中提供内容

环境信息(适用于任何操作系统和操作系统)

  1. ElasticPress 版本:3.5.4
  2. 弹性搜索版本:7.9
  3. WordPress:5.7

标签: wordpresselasticsearchindexingelasticpress

解决方案


推荐阅读