使用wooccommerce在自定义排序中添加meta_type


Add meta_type in custom sorting using woocommerce

我正在使用以下代码在wooccommerce中进行自定义排序。这很好用。唯一的问题是我必须按数字排序。我使用了meta_type = UNSIGNED,但这不起作用。

add_filter( 'woocommerce_get_catalog_ordering_args', 'custom_woocommerce_get_catalog_ordering_args' );
function custom_woocommerce_get_catalog_ordering_args( $args ) {
   $orderby_value = isset( $_GET['orderby'] ) ? woocommerce_clean( $_GET['orderby'] ) :    apply_filters( 'woocommerce_default_catalog_orderby', get_option( 'woocommerce_default_catalog_orderby' ) );
 if ( 'timer' == $orderby_value ) {
    $args['meta_key']   = '_auction_dates_to_time';
    $args['meta_type']  = 'UNSIGNED';
    $args['orderby']    = "meta_value";
    $args['order']      = 'ASC';
    $args['paged']      = $paged;
} 
if ( 'timer-desc' == $orderby_value ) {
    $args['meta_key']   = '_auction_dates_to_time';
    $args['meta_type']  = 'UNSIGNED';
    $args['orderby']    = "meta_value";
    $args['order']      = 'DESC';
    $args['paged']      = $paged;
 } 
return $args;
}
add_filter( 'woocommerce_default_catalog_orderby_options', 'custom_woocommerce_catalog_orderby' );
add_filter( 'woocommerce_catalog_orderby', 'custom_woocommerce_catalog_orderby' );
function custom_woocommerce_catalog_orderby( $sortby ) {
   $sortby['timer']   = 'Sort by Bid End Time: low to high';
   $sortby['timer-desc'] = 'Sort by Bid End Time: high to low';
   return $sortby;
}

请在这个问题上帮助我。

感谢

再次阅读文档和源代码。不管您在查询中将meta_type设置为什么(实际上它被忽略了,文档中没有这样的参数),实际数据仍然存储在wp_postmeta表中,meta_value列具有LONGTEXT类型。对LONGTEXT列进行排序应该会得到这些结果。这就是字典顺序的工作方式。

您可以做的只有的事情是将该列CAST为数字类型,从而告诉数据库它应该进行数字排序。通过自定义SQL查询,可以使用内置的WP_Query功能:

orderby(string|array)-按参数对检索到的帖子进行排序

"meta_value_num"-按数字元值排序(可用于版本2.8)。还要注意,还必须存在"meta_key=keyname"在查询中。该值允许如上所述进行数字排序在"meta_value"中。

幸运的是,wooccommerce通过设置$args['orderby'] = "meta_value_num";正好暴露了这一点,因为$args直接发送到WP_Query

此命令告诉WP_Querymeta_value强制转换为数字类型(使用+0):

case 'meta_value_num':
    $orderby = "$wpdb->postmeta.meta_value+0";
    break;