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

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

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

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 列存储相关概念和常见列式存储数据库(Hbase、德鲁依)

    列存储相关概念和常见列式存储数据库(Hbase、德鲁依)TableofContents列式存储数据库ExamplesofColumnStoreDBMSsHbaseTableRowColumnColumnFamilyColumnQualifierCellTimestampDruid(德鲁依)Cassandra参考列式存储数据库列式数据库是以列相关存储架构进行数据存储的数据库,主要…

    2022年7月14日
    22
  • MATLAB绘制B样条曲线[通俗易懂]

    MATLAB绘制B样条曲线[通俗易懂]1B样条曲线1.1B样条曲线定义B样条方法具有表示与设计自由型曲线曲面的强大功能,是形状数学描述的主流方法之一,另外B样条方法是目前工业产品几何定义国际标准——有理B样条方法(NURBS)的基础。B样条方法兼备了Bezier方法的一切优点,包括几何不变性,仿射不变性等等,同时克服了Bezier方法中由于整体表示带来不具有局部性质的缺点(移动一个控制顶点将会影响整个曲线)。B样条曲线方程可写为

    2022年6月18日
    123
  • python发邮件详解,smtplib和email模块详解

    python发邮件详解,smtplib和email模块详解在介绍具体的实现python发邮件的具体操作之前,我觉得有必要介绍下SMTP,更有助于理解python发邮件的实现原理。SMTP协议属于TCP/IP协议簇,即简单邮件传输协议,它是一组用于由源地址到目的地址传送邮件的规则,由它来控制信件的中转方式,python实现发邮件也是基于此基础上进行封装的。1.python发邮件所需要的基础包python发送邮件需要用到python自带的两个模块,s…

    2025年8月7日
    3
  • c++解决大整数乘法

    c++解决大整数乘法c++解决大整数乘法问题描述:求两个不超过200位的非负整数的积输入数据:输入有两行,每行是一个不超过200位的非负整数,没有多余的前导0。输出要求:输出只一行,即相乘后的结果。结果里不能有多余的前导0,即如果结果是342,那么不能输出0342。输入样例:1234567890098765432100输出样例:1219326311126352690000解题思路:采用列乘法竖式的求解思路,采用数组…

    2022年6月2日
    44
  • com.onseven.dbvis.DbVisualizerGUI

    com.onseven.dbvis.DbVisualizerGUIcom.onseven.dbvis.DbVisualizerGUI

    2022年4月23日
    354
  • React 回忆录(四)React 中的状态管理

    React 回忆录(四)React 中的状态管理

    2022年4月3日
    64

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

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