最后我想对缺货的产品进行分类。 它可以工作,但是我在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不包含它,因此它不会显示在我的页面上。
任何提示如何将其重新包含在我的页面上并保持排序?
答案 0 :(得分:1)
您使用的是“ GeneratePress”吗?
他们似乎注册了一个名为gp_elements
的自定义帖子类型。
由于您的过滤器函数在posts_clauses
钩子上运行,因此它与已钩住的其他函数一起运行。我不认为您会因为order_by_stock_status
函数而看到这种自定义帖子类型。
快速检查是切换主题(和/或可能停用与generatepress相关的插件),并再次监视您的查询。我敢打赌它会消失。
此外,幸运的是,该查询中的WHERE
子句应该对那些具有非空库存状态的产品评估为true,而忽略了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');
}
}