Wordpress WP Запрос/получение сообщений, в которых заголовок сообщения равен, возвращает все результаты


Я создал пользовательский тип записи под названием "фрагменты", где есть фрагменты данных, такие как "адрес", которые клиент может изменить.

Все названия фрагментов уникальны: Custom Post Type

Я создал простую функцию для возврата этих фрагментов, однако она работает не совсем правильно, и я не уверен, почему.

Функция:

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;
}

Вот пример вызова функции:

echo get_snippet('footer_address');

Проблема в следующем:

Он всегда будет возвращать все фрагменты и не фильтровать по post_title.

Даже если я использую get_posts(), он всегда будет возвращать все фрагменты в одном и том же порядке и не будет возвращать один фрагмент на основе post_title.

Вместо этого результат эквивалентен:

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

Почему он не будет фильтроваться по 'post_title'?

Спасибо

(Я также использую мультисайт)

Вот мой пользовательский код ввода типа сообщения:

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 );
Author: Jack Nicholson, 2015-08-12

2 answers

Я знаю, что это очень старый пост, но, возможно, кто-то будет искать решение так же, как я сегодня.

Оказывается, вам просто нужно использовать "заголовок" вместо "post_title".

Вот пример:

$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);
 3
Author: Andrew, 2017-06-07 15:37:14

Если вы все еще не можете получить какое-либо решение, попробуйте выполнить следующий запрос вручную:

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

 1
Author: nim, 2015-09-11 09:33:10