gpt4 book ai didi

php - wordpress posts_orderby 过滤器与插件中的自定义表

转载 作者:行者123 更新时间:2023-11-29 04:47:57 26 4
gpt4 key购买 nike

我正在开发一个 Wordpress 插件,需要使用我用我的插件创建的自定义表格来排序网站的帖子。

我不想更改主题中的代码,所以我在 codex 上找到了过滤器 posts_orderbyposts_join(在此处找到:https://codex.wordpress.org/Custom_Queries)。

自定义表格有这些值:

ID    slug    price 

在我添加这些行的插件文件中:

add_filter('posts_orderby','custom_orderby');
add_filter('posts_join','custom_join');

function custom_join($join){
global $wpdb;
$customTable = $wpdb->prefix.'custom_table';

if(!is_admin()){
$join .= " LEFT JOIN $customTable ON $wpdb->postmeta.meta_value = $customTable.slug";
}
return $join;
}
function custom_orderby($orderby_statement){
global $wpdb;
$customTable = $wpdb->prefix.'custom_table';

if(!is_admin()){
$orderby_statement = "$customTable.price DESC";
}
return $orderby_statement;
}

当我刷新索引页面时,它给我这个错误信息:

No Results Found

The page you requested could not be found. Try refining your search, or use the navigation above to locate the post.

我尝试使用以下代码直接在我的数据库上进行查询:

SELECT * FROM wp_posts t1
LEFT JOIN wp_postmeta t2 ON t1.ID = t2.post_id
LEFT JOIN wp_custom_table t3 ON t2.meta_value = t3.slug

ORDER BY t3.price DESC

而且有效。

所以我的插件文件中编写的代码有问题,但我无法弄清楚。

最佳答案

好的,我解决了。

问题是 post 查询不包含 postmeta 表,所以我将它添加到 custom_join 函数中,如下所示:

add_filter('posts_join','custom_join');
add_filter('posts_orderby','custom_orderby');

function custom_join($join){
global $wpdb;
$customTable = $wpdb->prefix."custom_table";

if(!is_admin){
$join .= "LEFT JOIN $wpdb->postmeta p1 ON $wpdb->posts.ID = p1.post_id";
$join .= "LEFT JOIN $customTable p2 ON p1.meta_value = p2.slug";
}

return $join;
}

function custom_orderby($orderby_statement){
global $wpdb;

if(!is_admin){
$orderby_statement = "p2.price DESC, $wpdb->posts.post_date DESC";
}

return $orderby_statement;
}

我还添加了 posts_groupby 过滤器,因为新查询给了我重复的帖子(很多重复的帖子)。

代码如下:

add_filter('posts_groupby','custom_groupby');

function custom_groupby($groupby){
global $wpdb;

if(!is_admin){
$groupby = "$wpdb->posts.ID";
}

return $groupby;
}

一切都写在插件文件中,但您也可以写在主题的 function.php 文件中。

如果您想在前端查看自定义查询,请记住包含if(!is_admin) 语句。

关于php - wordpress posts_orderby 过滤器与插件中的自定义表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15977188/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com