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_titles+LIKEs*('[^']+')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末尾(最后一个?>之前)即可!

www.npspro.cn软师兄
软师兄 » WordPress搜索文章自定义字段(例如:产品编号)
50T免费网盘资源大集合【持续更中~~~~】:点击查看