wordpress自定义搜索

wordpress自定义搜索默认下,wordpress的搜索范围只有文章的标题和文章内容,无法搜索自定义字段中的内容,现实情况是很多情况下我们可能会要搜索自定义字段中的内容。如果只是想搜索一到两个自定义字段中的内容,可以使用wordpress的内置函数meta_query变量。12345678910111213141516171

大家好,又见面了,我是你们的朋友全栈君。

默认下,wordpress的搜索范围只有文章的标题和文章内容,无法搜索自定义字段中的内容,现实情况是很多情况下我们可能会要搜索自定义字段中的内容。

如果只是想搜索一到两个自定义字段中的内容,可以使用wordpress的内置函数 meta_query变量。

<!– 代码 –>

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

// Query arguments

$args = array(

    ‘post_type’ => ‘post’,

    ‘post_status’ => ‘publish’,

);

$args[‘meta_query’][] =array(

    ‘key’ => ‘city’,

    ‘value’ => $city,

    ‘compare’ => ‘LIKE’,

);

$args[‘meta_query’][] =array(

    ‘key’ => ‘state’,

    ‘value’ => $state,

    ‘compare’ => ‘LIKE’,

);

$query = new WP_Query($args );

if ( $query->have_posts() ):while ( $query->have_posts() ) :$query->the_post();

// Do loop here

endwhile; endif;

这个方法并不适合于搜索更多及至全部的自定义字段,因为如果你有很多个自定义字段,这上请求将会变得非常的庞大,wordpress执行起来也同样的要花很多时间。根据我的测试,10个自定义字段,就花了超过1分钟的时间还没有搜索得结果。

所以,我写了一个解决方案,不使用meta_query写复杂的请求,而是使用简单的SQL语句,查询出所有的必须的post_id,于是一切就直接了当了:

<!– 代码二 –>

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

global $wpdb;

// 如果你使用自定义搜索框

// $keyword = sanitize_text_field( $_POST[‘keyword’] );

//如果你使用wordpress默认搜索框

 

$keyword = get_search_query();

$keyword = “%{$keyword}%”;

// 搜索所有的自定义字段

$post_ids_meta = $wpdb->get_col($wpdb->prepare( “

    SELECT DISTINCT post_id FROM {
$wpdb->postmeta}

    WHERE meta_value LIKE ‘%s’

“, $keyword ) );

// 在文章标题或文章内容中搜索

$post_ids_post = $wpdb->get_col($wpdb->prepare( “

    SELECT DISTINCT ID FROM {
$wpdb->posts}

    WHERE post_title LIKE ‘%s’

    OR post_content LIKE ‘%s’

“, $keyword, $keyword ) );

$post_ids = array_merge($post_ids_meta, $post_ids_post );

// 查询参数

$args = array(

    ‘post_type’   => ‘post’,

    ‘post_status’ => ‘publish’,

    ‘post__in’    => $post_ids,

);

$query = new WP_Query($args );

if ( $query->have_posts() ):while ( $query->have_posts() ) :$query->the_post();

// Do loop here

endwhile; endif;

在上面的代码中,做了自定义搜索框的查询和wrodpress默认搜索框两种方式,可以根据需要注释掉其中一个。

上面的代码中,搜索了所有文章自定义字段,文章标题,文章内容,返回是符合的文章的ID组成的数组。然后再使用wp_query做了一个自定义查询,使用这个方法,可以很方便地使用模板标签把文章内容显示出来。

你可以把代码放到主题文章中的search.php文章中,去替换wordpress默认的搜索框。你也可以把这代码粘贴到一个自定义搜索框中。

参考资料:http://www.deluxeblogtips.com/2012/04/search-all-custom-fields.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/159159.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • [Android] Bitmap的内存计算

    本文聚焦的问题1、Bitmap中像素数据占用多大内存?如何计算?2、不同图片来源对内存大小有什么影响?Bitmap bitmap = Bitmap.createBitmap(100,100,Bitmap.Config.ARGB_8888);依然以如此声明一个bitmap为例,参数就决定了bitmap的大小。(以Android 8.0+平台为例,这行代码执行后占用的总内存大小=bitmap在…

  • 简单线性回归-最小二乘法推导过程

    简单线性回归-最小二乘法推导过程最近学习线性回归,自己推导了一下最小二乘法。 其他参考文章:https://blog.csdn.net/chasdmeng/article/details/38869941?utm_source=blogxgwz0https://blog.csdn.net/iterate7/article/details/78992015要是你在西安,感兴趣一起学习AIOPS,欢迎加入QQ群…

  • SAS学习笔记25 t检验(单个样本t检验、配对样本t检验、两个独立样本t检验及方差不齐时的t’检验)…

    SAS学习笔记25 t检验(单个样本t检验、配对样本t检验、两个独立样本t检验及方差不齐时的t’检验)…根据研究设计和资料的性质有单个样本t检验、配对样本t检验、两个独立样本t检验以及在方差不齐时的t’检验单样本t检验单样本t检验(one-samplet-test)又称单样本均数t检验,适用于样本均数$\overline{X}$与已知总体均数$\mu_{0}$的比较,其比较目的是检验样本均数所代表的总体均数µ是否与已知总体均数$\mu_{0}$有差别已知总体均数$\mu_{0…

  • JAVA保留两位小数_精确小数点后两位

    JAVA保留两位小数_精确小数点后两位这篇文章主要介绍了java使double类型保留两位小数的方法,大家参考使用吧mportjava.text.DecimalFormat;DecimalFormatdf=newDecimalFormat(“######0.00”);doubled1=3.23456doubled2=0.0;doubled3=2.0;df.format(d1);df.format(…

  • sdio接口定义_sdio接口

    sdio接口定义_sdio接口转:https://www.cnblogs.com/hellokitty2/p/10981084.htmlSDIO接口一、SDIO简介SDIO接口是在SD内存卡接口的基础上发展起来的接口,SDIO接口兼容以前的SD内存卡,并且可以连接SDIO接口的设备。SDIO1.0标准定义了两种类型的SDIO卡:1.全速的SDIO卡,传输率可以超过100Mbps;2.低速的SDIO卡,支援的时脉速率…

  • X3D 概念

    X3D 概念Extensible3D(X3D)Part1:Architectureandbasecomponents4Concepts概念4.1一般4.1.1主题此条款描述了X3D的核心概念,包括:如何创建和回放X3D场景,X3D场景的运行时语法,组件和概貌构成的模块化结构,通过层概念保证顺应性,数据编码语法,程序存取,网络化因素。表

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号