wordpress提高wordpress搜索准确度

默认情况下,本机WordPress搜索对您的数据库执行如下查询:

默认wordpress搜索sql语句

是按照发布时间排序的,这样的搜索结果的相关性并不强,这是WordPress为了返回搜索结果而进行的大量搜索, 每次查询wp_posts进行每次检查时,MySQL都会处理wp_posts中的所有行。 当wp_posts表中有成千上万的行时,此查询很快就会变得很慢,而且也并不精准,可以通过更改wordpress的默认搜索查询sql语句来提升wordpress搜索准确度,实现的方法就是在当前wordpress主题的functions.php 添加如下代码:

if(is_search()){
    add_filter('posts_orderby_request', 'hx_search_orderby_filter');
}

function hx_search_orderby_filter($orderby = ''){
    global $wpdb;
    $keyword = $wpdb->prepare($_REQUEST['s']);
    return "((CASE WHEN {$wpdb->posts}.post_title LIKE '%{$keyword}%' THEN 2 ELSE 0 END) + (CASE WHEN {$wpdb->posts}.post_content LIKE '%{$keyword}%' THEN 1 ELSE 0 END)) DESC,{$wpdb->posts}.post_modified DESC, {$wpdb->posts}.ID ASC";
}

上面的排序方法很简单:当文章标题含有关键字的时候给予权重值 2,内容里含有关键字的时候给予权重值 1,把两个权重值相加以后降序排列。然后才用文章修改时间和ID降序作为候补排序方法。这样一来,搜索出来的结果就更加准确了。

其他特别推荐文章:

WordPress搜索结果高亮显示代码版

我爱主题网 自2012
主题:260+ 销售:1000+
兼容浏览器

电话咨询

7*12服务咨询电话:

133-7205-6573

微信咨询