Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/php/271.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Php 显示缺货产品-目标自定义帖子类型_Php_Sql_Wordpress_Woocommerce - Fatal编程技术网

Php 显示缺货产品-目标自定义帖子类型

Php 显示缺货产品-目标自定义帖子类型,php,sql,wordpress,woocommerce,Php,Sql,Wordpress,Woocommerce,我正试图在最后整理我的缺货产品。 这是可行的,但我在DACrosby找到的查询也针对自定义帖子类型。 这是原始代码: 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(

我正试图在最后整理我的缺货产品。 这是可行的,但我在DACrosby找到的查询也针对自定义帖子类型。

这是原始代码:

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_元素,这是我的主题的自定义帖子类型。 因为where没有包含它,所以它不会出现在我的页面上

有没有关于如何将其包含回我的页面并保持排序的提示?

您正在使用吗

它们似乎注册了一个名为gp_元素的自定义post类型

由于您的过滤器函数在posts_子句挂钩上运行,因此它与其他挂接在那里的函数一起运行。我认为您没有看到这种定制的帖子类型是由于orderbystock状态函数的结果

快速检查是切换主题和/或可能停用generatepress相关插件,并再次监视您的查询。我敢打赌它一定会出现

此外,幸运的是,该查询中的WHERE子句应该为那些具有非空库存状态的产品计算true,并忽略gp_元素条件。我将这段摘录括在括号内,以便更清楚地说明操作顺序。因此,也许您还可以检查数据本身,以确保您已经获得了带有要进行比较/排序的值的_stock_status元键

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

谢谢你的帮助。我想用generatepress。有一个显示自定义标题的元素模块。当我运行上面的代码时,头代码被过滤掉。我想把它放回我的页面。因为我不能调整查询本身,所以需要在代码中完成。有没有关于这个的小册子?更新了一个额外的方法非常感谢更新。但这只会做查询,如果它不是管理员?查询可以随时运行。我也只想看看GP_元素。这些被代码过滤掉了。因此,我认为我们需要在php代码中的where子句中添加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');
    }
}