【发布时间】:2018-05-05 12:11:04
【问题描述】:
我有一个返回$shipping_method_id 的函数(例如flat_rate:3)。我想获取此配送方式费率 ID 的区域名称...
如何根据运输方式费率ID获取区域名称?
【问题讨论】:
标签: php sql wordpress woocommerce shipping
我有一个返回$shipping_method_id 的函数(例如flat_rate:3)。我想获取此配送方式费率 ID 的区域名称...
如何根据运输方式费率ID获取区域名称?
【问题讨论】:
标签: php sql wordpress woocommerce shipping
构建一个自定义函数,以这种方式使用非常简单的 SQL 查询:
function get_shipping_zone_from_method_rate_id( $method_rate_id ){
global $wpdb;
$data = explode( ':', $method_rate_id );
$method_id = $data[0];
$instance_id = $data[1];
// The first SQL query
$zone_id = $wpdb->get_col( "
SELECT wszm.zone_id
FROM {$wpdb->prefix}woocommerce_shipping_zone_methods as wszm
WHERE wszm.instance_id = '$instance_id'
AND wszm.method_id LIKE '$method_id'
" );
$zone_id = reset($zone_id); // converting to string
// 1. Wrong Shipping method rate id
if( empty($zone_id) )
{
return __("Error! doesn't exist…");
}
// 2. Default WC Zone name
elseif( $zone_id == 0 )
{
return __("All Other countries");
}
// 3. Created Zone name
else
{
// The 2nd SQL query
$zone_name = $wpdb->get_col( "
SELECT wsz.zone_name
FROM {$wpdb->prefix}woocommerce_shipping_zones as wsz
WHERE wsz.zone_id = '$zone_id'
" );
return reset($zone_name); // converting to string and returning the value
}
}
代码进入您的活动子主题(或主题)的 function.php 文件或任何插件文件中。
经过测试并且有效。
使用示例 (输出区域名称):
// Set HERE your shipping method rate id
$rate_id = 'flat_rate:3';
// Get the zone name
$zone_name = get_shipping_zone_from_method_rate_id( $rate_id );
// Output zone name
echo $zone_name;
【讨论】: