Eu verifiquei e não vi uma resposta que funcione até o momento. Eu tenho um WP_Query com os seguintes argumentos:
$args = array(
'post_status' => 'publish',
'post_type' => 'listing',
'meta_key' => 'client_feedback_score',
'orderby' => 'client_feedback_score',
'order' => 'DESC'
);
$query = new WP_Query($args);
Desejo ordenar os resultados pelo campo de postagem personalizado 'client_feedback_score', do menor para o maior. Mas isso não parece funcionar ... alguém pode me apontar na direção certa?
EDITAR (RESOLVIDO):
Graças à resposta de Milo, eis o código de trabalho para solicitar por um meta-valor numérico:
$args = array(
'post_status' => 'publish',
'post_type' => 'listing',
'meta_key' => 'client_feedback_score',
'orderby' => 'meta_value_num',
'order' => 'DESC'
);
custom-field
wp-query
order
Adam Moss
fonte
fonte
meta_key
ainda não existir para a postagem, a postagem será ignorada.my_meta_key
, para cada postagem para gerar a ordem que você desejar. Etapa 2 Você definemeta_key
sua consulta paramy_meta_key
. Isso instrui o WordPress a consultar as postagens que possuem essa chave. Etapa 3 Definaorderby
na sua consulta comometa_value_num
. Isso diz ao WordPress para não apenas consultar as postagensmy_meta_key
, mas também para ordenar numericamente por essa chave. Esse argumento de consulta é o único lugar que você verá ou usarámeta_value_num
.meta_key
a eles antes de executar a consulta fim