Se você quiser testar seu SQL personalizado para ver como isso afeta o tempo de carregamento, tente essa troca de consulta:
/**
* Restrict the potential slow query in the meta_form() to the current post ID.
*
* @see http://wordpress.stackexchange.com/a/187712/26350
*/
add_action( 'add_meta_boxes_post', function( $post )
{
add_filter( 'query', function( $sql ) use ( $post )
{
global $wpdb;
$find = "SELECT meta_key
FROM $wpdb->postmeta
GROUP BY meta_key
HAVING meta_key NOT LIKE '\\_%'
ORDER BY meta_key
LIMIT 30";
if( preg_replace( '/\s+/', ' ', $sql ) === preg_replace( '/\s+/', ' ', $find )
&& $post instanceof WP_Post
) {
$post_id = (int) $post->ID;
$sql = "SELECT meta_key
FROM $wpdb->postmeta
WHERE post_id = {$post_id}
GROUP BY meta_key
HAVING meta_key NOT LIKE '\\_%'
ORDER BY meta_key
LIMIT 30";
}
return $sql;
} );
} );
Aqui usamos o add_meta_boxes_{$post_type}
hook, onde $post_type = 'post'
.
Aqui nós trocamos toda a consulta, mas também poderíamos ajustá-la para suportar o limite dinâmico.
Espero que você possa ajustar isso às suas necessidades.
Atualização:
Esta consulta de núcleo SQL potencialmente lenta foi agora ajustada no WP versão 4.3 de
SELECT meta_key
FROM wp_postmeta
GROUP BY meta_key
HAVING meta_key NOT LIKE '\_%'
ORDER BY meta_key
LIMIT 30
para:
SELECT DISTINCT meta_key
FROM wp_postmeta
WHERE meta_key NOT BETWEEN '_' AND '_z'
HAVING meta_key NOT LIKE '\_%'
ORDER BY meta_key
LIMIT 30;
Confira o tíquete principal # 24498 para obter mais informações.