Loading
0

WordPress搜索文章自定义字段(例如:产品编号)

wordpress默认搜索是搜索文章标题以及检索文章内容里的关键字,但是对于一些电商网站来说,搜索产品编号也是很重要的一部分,但是产品编号一般是一个自定义字段,无法被搜索到,这时该怎么办呢?

接下来让模板兔给出解决方案:

首先,让系统的搜索能搜索到postmeta数据表:

function MBT_search_join( $join ) {
 global $wpdb;
 if ( is_search() ) {
 $join .=' LEFT JOIN '.$wpdb->postmeta. ' ON '. $wpdb->posts . '.ID = ' . $wpdb->postmeta 
    . '.post_id ';
 }
 return $join;
}
add_filter('posts_join', 'MBT_search_join' );

然后在模糊查询里加入查询字段:

function MBT_search_where( $where ) {
 global $pagenow, $wpdb;
 if ( is_search() ) {
 $where = preg_replace(
 "/\(\s*".$wpdb->posts.".post_title\s+LIKE\s*(\'[^\']+\')\s*\)/",
 "(".$wpdb->posts.".post_title LIKE $1) OR (".$wpdb->postmeta.".meta_value LIKE $1)", 
  $where );
 }
 return $where;
}
add_filter( 'posts_where', 'MBT_search_where' );

但是,这样的话可能会出现搜索结果重复的情况,那么得用数据库关键字DISTINCT过滤下:

function MBT_search_distinct( $where ) {
 global $wpdb;
 if ( is_search() ) {
 return "DISTINCT";
 }
 return $where;
}
add_filter( 'posts_distinct', 'MBT_search_distinct' );

将以上三段代码加到主题的functions.php末尾(最后一个?>之前)即可!

特别声明:1、本站仅提供源码学习下载,使用者需具备一定的技术基础,源码费用仅为站长辛苦整理费,不代表源码自身价值也不包含任何服务,如需完美运营请到官方购买。如需搭建、二开、bug修复等服务需额外收费,如果源码侵犯了您的利益请联系客服处理! 2、用户必须遵守《计算机软件保护条例(2013修订)》第十七条:为了学习和研究软件内含的设计思想和原理,通过安装、显示、传输或者存储软件等方式使用软件的,可以不经软件著作权人许可,不向其支付报酬。鉴于此条例,用户从本平台下载的全部源码(软件)仅限学习研究,未经版权归属者授权不得商用,若因商用引起的版权纠纷,一切责任均由使用者自行承担,本平台所属公司及其雇员不承担任何法律责任。本站邮箱:weituiw@qq.com