WordPress WP_Query/get_posts donde post_title es igual devuelve todos los resultados

3 minutos de lectura

Creé un tipo de publicación personalizada llamada ‘fragmentos’ donde hay fragmentos de datos como ‘dirección’ que el cliente puede cambiar.

El título de los fragmentos es único:
Tipo de publicación personalizada

Creé una función simple para devolver estos fragmentos, sin embargo, no funciona del todo bien y no estoy seguro de por qué.

Función:

function get_snippet($snippet_title) {
    $snippet_page = new WP_Query(array(
        'post_type' => 'snippets',
        'post_title' => $snippet_title
    ));
    return $snippet_page->posts[0]->post_content;
}

Aquí hay un ejemplo de llamada a la función:

echo get_snippet('footer_address');

El problema es:

Siempre devolverá todos los fragmentos y no filtrará por post_title.

Incluso si uso get_posts() siempre devolverá todos los fragmentos en el mismo orden y no devolverá el único fragmento basado en post_title.

El resultado es en cambio el equivalente a:

$snippet_page = new WP_Query(array(
    'post_type' => 'snippets'
));

¿Por qué no filtrará por ‘post_title’?

Gracias

(También estoy usando multisitio)

Aquí está mi código de inicio de tipo de publicación personalizado:

function snippets() {
    $labels = array(
        'name'                => _x( 'Snippets', 'Post Type General Name', 'text_domain' ),
        'singular_name'       => _x( 'Snippet', 'Post Type Singular Name', 'text_domain' ),
        'menu_name'           => __( 'Snippets', 'text_domain' ),
        'name_admin_bar'      => __( 'Snippets', 'text_domain' ),
        'parent_item_colon'   => __( 'Parent Item:', 'text_domain' ),
        'all_items'           => __( 'All Snippets', 'text_domain' ),
        'add_new_item'        => __( 'Add New Snippet', 'text_domain' ),
        'add_new'             => __( 'Add New Snippet', 'text_domain' ),
        'new_item'            => __( 'New Snippet', 'text_domain' ),
        'edit_item'           => __( 'Edit Snippet', 'text_domain' ),
        'update_item'         => __( 'Update Snippet', 'text_domain' ),
        'view_item'           => __( 'View Snippet', 'text_domain' ),
        'search_items'        => __( 'Search Snippet', 'text_domain' ),
        'not_found'           => __( 'Not found', 'text_domain' ),
        'not_found_in_trash'  => __( 'Not found in Trash', 'text_domain' ),
    );
    $args = array(
        'label'               => __( 'snippets', 'text_domain' ),
        'description'         => __( 'For custom snippets of code/data.', 'text_domain' ),
        'labels'              => $labels,
        'supports'            => array( ),
        'hierarchical'        => false,
        'public'              => false,
        'show_ui'             => true,
        'show_in_menu'        => true,
        'menu_icon'           => 'dashicons-tagcloud',
        'menu_position'       => 5,
        'show_in_admin_bar'   => true,
        'show_in_nav_menus'   => false,
        'can_export'          => true,
        'has_archive'         => true,      
        'exclude_from_search' => true,
        'publicly_queryable'  => false,
        'capability_type'     => 'page',
    );
    register_post_type( 'snippets', $args );
}
add_action( 'init', 'snippets', 0 );

  • Para consultar publicaciones a través del título, consulte wordpress.stackexchange.com/a/18715/62744

    – vard

    12 de agosto de 2015 a las 9:39

  • Bueno, solo reemplaza LIKE por = y estás listo para irte. Hasta donde yo sé y teniendo en cuenta la Documentación de WP_Queryparece que no puede consultar a través del título, aunque puede consultar a través del nombre de slug.

    – vard

    12 de agosto de 2015 a las 9:46

  • En ese caso, no obtendré una mejor respuesta si no puede consultar usando post_title! Gracias por su respuesta, probado y funcionando 🙂

    – Jacobo

    12 de agosto de 2015 a las 9:55

Sé que esta es una publicación muy antigua, pero tal vez alguien busque la solución como lo hice yo hoy.

Resulta que solo necesita usar ‘título’ en lugar de ‘post_title’.

Aquí hay un ejemplo:

$author_id = 20;
$args = array(
    'post_type' => 'attachment',
    'post_mime_type' => 'image',
    'post_status' => 'inherit',
    'title' => 'Reviewer Plugin - User review image',
    'author' => $author_id,
); 
$attachments = get_posts($args);
if ($attachments) {
    foreach ($attachments as $attachedfile) {
        $mediaIds =  $attachedfile->ID .','. $mediaIds;
    }
    $mediaIds = rtrim($mediaIds,",");
} 
print_r($mediaIds);

  • ¡Gran hallazgo! Cambié la respuesta aceptada (¡Lo siento, Nim!).

    – Jacobo

    7 junio 2017 a las 18:36


avatar de usuario
nim

Si aún no puede obtener ninguna solución, intente a continuación consultar manualmente:

global $wpdb;
$res = $wpdb->get_results("SELECT * FROM wp_posts where post_type="snippet" AND post_title="".$snippet_title.""");

¿Ha sido útil esta solución?