7折
减价出售
¥799
默认情况下,本机WordPress搜索对您的数据库执行如下查询:
是按照发布时间排序的,这样的搜索结果的相关性并不强,这是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降序作为候补排序方法。这样一来,搜索出来的结果就更加准确了。
其他特别推荐文章:
减价出售
减价出售
减价出售
减价出售
电话咨询
133-7205-6573
微信咨询