显示缺货产品 - 定位自定义帖子类型

Posted

技术标签:

【中文标题】显示缺货产品 - 定位自定义帖子类型【英文标题】:Show out of stock products - targets custom post types 【发布时间】:2020-08-18 12:46:27 【问题描述】:

我正在尝试最后整理我缺货的产品。 它有效,但我通过 DACrosby 找到的查询也针对自定义帖子类型。 Show Out of stock products at the end in Woocommerce

这是原始代码:

add_filter('posts_clauses', 'order_by_stock_status');
function order_by_stock_status($posts_clauses) 
    global $wpdb;
    // only change query on WooCommerce loops
    if (is_woocommerce() && (is_shop() || is_product_category() || is_product_tag() || is_product_taxonomy())) 
        $posts_clauses['join'] .= " INNER JOIN $wpdb->postmeta istockstatus ON ($wpdb->posts.ID = istockstatus.post_id) ";
        $posts_clauses['orderby'] = " istockstatus.meta_value ASC, " . $posts_clauses['orderby'];
        $posts_clauses['where'] = " AND istockstatus.meta_key = '_stock_status' AND istockstatus.meta_value <> '' " . $posts_clauses['where'];
    
    return $posts_clauses;

当我监控我的查询时,我看到了这个:

SELECT SQL_CALC_FOUND_ROWS wp_posts.ID
FROM wp_posts
LEFT JOIN wp_term_relationships
ON (wp_posts.ID = wp_term_relationships.object_id)
LEFT JOIN wp_term_relationships AS tt1
ON (wp_posts.ID = tt1.object_id)
LEFT JOIN wp_icl_translations wpml_translations
ON wp_posts.ID = wpml_translations.element_id
AND wpml_translations.element_type = CONCAT('post_', wp_posts.post_type)
INNER JOIN wp_postmeta istockstatus
ON (wp_posts.ID = istockstatus.post_id)
WHERE 1=1
AND istockstatus.meta_key = '_stock_status'
AND istockstatus.meta_value <> ''
OR wp_posts.post_type = 'gp_elements'
AND ( wp_term_relationships.term_taxonomy_id IN (1816)
AND wp_posts.ID NOT IN (
SELECT object_id
FROM wp_term_relationships
WHERE term_taxonomy_id IN (10) )
AND tt1.term_taxonomy_id IN (1816) )
AND wp_posts.post_type = 'product'
AND (wp_posts.post_status = 'publish'
OR wp_posts.post_status = 'private')
AND ( ( ( wpml_translations.language_code = 'nl'
OR ( wpml_translations.language_code = 'nl'
AND wp_posts.post_type IN ( 'gp_elements' )
AND ( ( (
SELECT COUNT(element_id)
FROM wp_icl_translations
WHERE trid = wpml_translations.trid
AND language_code = 'nl' ) = 0 )
OR ( (
SELECT COUNT(element_id)
FROM wp_icl_translations t2 JOIN wp_posts p
ON p.id = t2.element_id
WHERE t2.trid = wpml_translations.trid
AND t2.language_code = 'nl'
AND ( p.post_status = 'publish'
OR p.post_type='attachment'
AND p.post_status = 'inherit' ) ) = 0 ) ) ) )
AND wp_posts.post_type IN ('post','page','attachment','wp_block','product','product_variation','gp_elements' ) )
OR wp_posts.post_type NOT IN ('post','page','attachment','wp_block','product','product_variation','gp_elements' ) )
GROUP BY wp_posts.ID
ORDER BY istockstatus.meta_value ASC, wp_posts.menu_order ASC, wp_posts.post_title ASC
LIMIT 0, 20

如您所见,它还以 gp_elements 为目标,这是我的主题的自定义帖子类型。 由于 where 不包含它,因此它不会显示在我的页面上。

任何提示如何将其重新包含在我的页面上并保持排序?

【问题讨论】:

【参考方案1】:

您使用的是“GeneratePress”吗?

他们似乎注册了一个名为 gp_elements 的自定义帖子类型。

由于您的过滤器函数在posts_clauses 挂钩上运行,因此它与已挂钩的其他函数一起运行。我认为您没有看到这种自定义帖子类型是由 order_by_stock_status 函数定位的。

快速检查是切换主题(和/或可能停用与 generatepress 相关的插件),并再次监控您的查询。我敢打赌它会消失。

此外,幸运的是,该查询中的WHERE 子句应该对那些具有非空库存状态的产品评估为真,而忽略gp_elements 标准。我已将这段摘录括起来以使操作顺序更清晰。因此,也许您还可以检查数据本身,以确保您有 _stock_status 元键以及要比较/排序的值。

// ...
WHERE (
   1=1
   AND istockstatus.meta_key = '_stock_status'
   AND istockstatus.meta_value <> ''
 )
 OR wp_posts.post_type = 'gp_elements'`

(当然,可以取消在 posts_clauses 钩子上过滤的 generatepress 函数,但它也会带来一系列问题。)

编辑:根据您的评论,如果您想另辟蹊径并仅在有时添加您的子句(不妨碍 GeneratePress 的标题),您可以尝试根据查询进行条件过滤。您可能需要在调用标头之前取消挂钩此函数;不看GP的内部就很难说。

add_action('pre_get_posts', 'sometimes_add_filter');

function sometimes_add_filter($query) 
    if (!is_admin() && $query->is_main_query() 
        add_filter('posts_clauses', 'order_by_stock_status');
    

【讨论】:

感谢您的帮助。我很喜欢使用generatepress。有一个显示自定义标题的元素模块。当我运行上面的代码时,标题代码被过滤掉了。我希望它回到我的页面上。由于我无法调整查询本身,因此需要在代码中完成。有什么帮助吗? 使用其他方法更新 非常感谢您的更新。但这只会在不是管理员的情况下进行查询?查询可以随时运行。我也只想看到 GP_elements。这些被代码过滤掉了。所以我认为我们需要将 GP_Elements 添加到 php 代码中的 where 子句中。我只是不知道如何定位它。

以上是关于显示缺货产品 - 定位自定义帖子类型的主要内容,如果未能解决你的问题,请参考以下文章

当 WooCommerce 档案中的产品缺货时删除自定义数量字段

在 WordPress 管理列帖子/产品自定义帖子类型中显示 Slug

自定义帖子类型的 WooCommerce 产品

在最近的订单模板和管理订单上显示产品帖子类型高级自定义字段(woocommerce)

在 Woocommerce 中使用自定义元数据隐藏“缺货”产品

Wordpress 自定义帖子类型分类 - 获取特定内容