在Wordpress中仅使用元关键字进行搜索

在Wordpress中仅使用元关键字进行搜索,wordpress,Wordpress,我需要帮助来进行查询,以自定义默认的wordpress搜索。我不想在wordpress搜索中包含标题、内容或摘录,但我想基于那个篇文章的元值进行搜索 在默认的wordpress搜索中,wordpress在“和”条件下添加元查询。如果有一个方法,如果元查询加载项或条件,它也将是罚款 请帮助我创建了一个ajax,从中我将输入文本作为“搜索文本”发送,并从存储在Posteta中的meta_键“job_is_featured”值检查文本是否为特征。还可以检查自定义帖子类型类别id $catid

我需要帮助来进行查询,以自定义默认的wordpress搜索。我不想在wordpress搜索中包含标题、内容或摘录,但我想基于那个篇文章的元值进行搜索

在默认的wordpress搜索中,wordpress在“和”条件下添加元查询。如果有一个方法,如果元查询加载项或条件,它也将是罚款


请帮助

我创建了一个ajax,从中我将输入文本作为“搜索文本”发送,并从存储在Posteta中的meta_键“job_is_featured”值检查文本是否为特征。还可以检查自定义帖子类型类别id

     $catids = '22';
  $args = array(
'post_type' => 'job', 'order' => 'DESC','posts_per_page' => '-1','s' => 'search_text' ,'orderby' => 'meta_value',
'tax_query' => array(
    array(
        'taxonomy' => 'job-category',
        'field'    => 'term_id',
        'terms' => $catids,
    ),
   ),
   'meta_query' => array(
'relation' => 'AND',
array(
'relation' => 'OR',
    array(
        'key' => 'job_is_featured',
        'value'    => 1,
        'compare' => '=',
    ),
    array(
        'key' => 'job_is_featured',
        'value'    => 0,
        'compare' => '=',
    ),
),
    array(
        'key' => 'job_location',
        'value'    => 'search_text',
        'compare' => 'LIKE',
    ),
),

 );
$the_query = new WP_Query( $args );

如果您指的是更改搜索结果页面上的查询(例如
http://example.com/?s=hello
),然后尝试以下选项之一:

选项#1

这是为了:

我不想在wordpress中包含标题、内容或摘录 搜寻

钩住
pre_get_posts
并清空
s
参数

add_action( 'pre_get_posts', function( $wp_query ){
    if ( $wp_query->is_main_query() && $wp_query->is_search() ) {
        $wp_query->set( 's', '' );
    }
});
选项2

这是为了:

默认情况下,wordpress搜索wordpress在“和”中添加元查询 条件如果有一种方法,如果元查询加载项或条件,它将 也可以

钩住
get\u meta\u sql
并用
替换

add_filter( 'get_meta_sql', function( $sql, $meta_query, $type, $primary_table ){
    global $wpdb;

    if (
        'post' === $type &&
        $wpdb->posts === $primary_table &&
        is_main_query() && is_search()
    ) {
        if ( $sql['where'] && ' AND (' === substr( $sql['where'], 0, 6 ) ) {
            $sql['where'] = ' OR ' . substr( $sql['where'], 5 );
        }
    }

    return $sql;
}, 10, 4 );
选项#3

创建自定义搜索页面并使用自定义
WP\u Query
实例查询帖子

$q = new WP_Query([
    'meta_key'   => 'some_key',
    'meta_value' => 'some_value',
    // Or use meta_query
]);
选项#1和#2都很棘手,可能与网站上的插件或修改搜索相关参数/查询的任何自定义代码冲突。甚至是标准查询。因此,使用代码的风险由您自己承担


希望对您有所帮助。

以下是您需要在函数中添加的代码。php

这段代码将与Post-Meta和Taxonomy一起使用

if(!function_exists('custom_wp_meta_and_tax_search')){
    function custom_wp_meta_and_tax_search($search_args){

        /* taxonomy query and meta query arrays */
        $tax_query = array();
        $meta_query = array();

        /* Keyword Based Search */
        if( isset ( $_GET['keyword'] ) ) {
            $keyword = trim( $_GET['keyword'] );
            if ( ! empty( $keyword ) ) {
                $search_args['s'] = $keyword;
            }
        }

        /* Custom Meta Key Parameter */ 
        if( isset($_GET['meta_input']) && ($_GET['meta_input'] != 'any')){
            $meta_query[] = array(
                'key' => 'custom_meta_key',
                'value' => $_GET['meta_input'],
                'compare' => 'like',                    
            );
        }

        $min_value = '';
        $max_value = '';
        if(isset($_GET['min-value']) && $_GET['min-value'] <> 'any'){
            $min_value = $_GET['min-value'];
        }

        if(isset($_GET['max-value']) && $_GET['max-value'] <> 'any'){
            $max_value = $_GET['max-value'];
        }
        /* Logic for Min and Max value Parameters */
        /* You need to replace custom_tax with custom taxonomy */
        if( isset($min_value) && ($min_value != 'any') && isset($max_value) && ($max_value != 'any') ){

            $min_value = doubleval($min_value);
            $max_value = doubleval($max_value);
            if( $min_value >= 0 && $max_value > $min_value ){
                $meta_query[] = array(
                    'key' => 'custom_tax',
                    'value' => array( $min_value, $max_value ),
                    'type' => 'NUMERIC',
                    'compare' => 'BETWEEN'
                );
            }
        }else if( isset($min_value) && ($min_value != 'any') ){
            $min_value = doubleval($min_value);
            if( $min_value > 0 ){
                $meta_query[] = array(
                    'key' => 'custom_tax',
                    'value' => $min_value,
                    'type' => 'NUMERIC',
                    'compare' => '>='
                );
            }
        }else if( isset($max_value) && ($max_value != 'any') ){
            $max_value = doubleval($max_value);
            if( $max_value > 0 ){
                $meta_query[] = array(
                    'key' => 'custom_tax',
                    'value' => $max_value,
                    'type' => 'NUMERIC',
                    'compare' => '<='
                );
            }
        }

        // /* if more than one taxonomies exist then specify the relation */
        $tax_count = count( $tax_query );
        if( $tax_count > 1 ){
            $tax_query['relation'] = 'AND';
        }

        /* if more than one meta query elements exist then specify the relation */
        $meta_count = count( $meta_query );
        if( $meta_count > 1 ){
            $meta_query['relation'] = 'AND';
        }

        if( $tax_count > 0 ){
            $search_args['tax_query'] = $tax_query;
        }

        /* if meta query has some values then add it to base home page query */
        $search_args['meta_query'] = $meta_query;


        /* Sort By meta value */
        /* You need to replace "custom_meta_key" with the key of custom field you created with post. */
        if( (isset($min_value) && ($min_value != 'any')) || ( isset($max_value) && ($max_value != 'any') ) ){
            $search_args['orderby'] = 'meta_value_num';
            $search_args['meta_key'] = 'custom_meta_key';
            $search_args['order'] = 'ASC';
        }



        return $search_args;
    }
}
add_filter('custom_search_parameters','custom_wp_meta_and_tax_search');
将此添加到function.php中 用法
想一想,你首先应该看看。默认关系是
,但您可以使用
等更改它。如果这不是您的问题,那么,请更详细并添加一些示例,您想知道的是避免WP\u Meta\u查询,它将在不同的元键条件之间设置关系。但在搜索中,当您在默认搜索查询中添加元查询时,查询将看起来像where1=1和(标题类似于某物或内容类似于某物或摘录类似于某物)和(多个元条件将根据您的数组在此处pu)我希望这些元条件与内容、标题和注释具有“或”关系。。这是您想要的吗(您可以使用
WP\u User\u Query
,而不是
WP\u Query
)?我想您对我的问题有点困惑,让我再次解释一下,默认的wordpress搜索查询从标题、摘录和内容中搜索相关内容,条件如下(where-title-like关键字或extract-like关键字或content-like关键字)之后,当您添加更多类似meta的参数时,它将处于以下状态(where(title-like关键字或extract-like关键字或content-like关键字)和(meta-like关键字或meta-like关键字))我想更改此选项,改为选项3基本上不修改全局
$wp\u query
对象。但我将该选项放在列表中,因为如果我是你,我可能会选择该选项。
$custom_search_args = array(
    'post_type' => 'post',
    'posts_per_page' => -1,
    'paged' => $paged,  
);
$custom_search_args = apply_filters('custom_search_parameters',$custom_search_args);
$search_query = new WP_Query( $custom_search_args );
                add_action( 'pre_get_posts', function( $q )
                {
                if( $title = $q->get( '_meta_or_title' ) )
                {
                add_filter( 'get_meta_sql', function( $sql ) use ( $title )
                {
                global $wpdb;

                // Only run once:
                static $nr = 0; 
                if( 0 != $nr++ ) return $sql;

                // Modified WHERE
                $sql['where'] = sprintf(
                " AND ( %s OR %s ) ",
                $wpdb->prepare( "{$wpdb->posts}.post_title like '%%%s%%'", $title),
                mb_substr( $sql['where'], 5, mb_strlen( $sql['where'] ) )
                );

                return $sql;
                });
                }
                });
                $meta_query = array();
                $args = array();
                $search_string = "test";

                $meta_query[] = array(
                'key' => 'staff_name',
                'value' => $search_string,
                'compare' => 'LIKE'
                );
                $meta_query[] = array(
                'key' => 'staff_email',
                'value' => $search_string,
                'compare' => 'LIKE'
                );

                //if there is more than one meta query 'or' them
                if(count($meta_query) > 1) {
                $meta_query['relation'] = 'OR';
                }

                // The Query
                $args['post_type'] = "staff";
                $args['_meta_or_title'] = $search_string; //not using 's' anymore
                $args['meta_query'] = $meta_query;



                $the_query = new WP_Query($args)