Как создать связь между двумя произвольными типами записей?
Я хочу создать базу данных телесериалов с помощью WordPress. Я следовал некоторым руководствам и создал два произвольных типа записей: один для movies
, другой для series
. Я следовал этой статье для структуры.
Мой вопрос: как создать связь между типами записей фильмов и сериалов?

Использование плагина
Некоторые очень хорошие плагины для работы со связями:
Использование метабокса
Вы можете создать простую связь между записями с помощью метабоксов:
add_action( 'admin_init', 'add_meta_boxes' );
function add_meta_boxes() {
add_meta_box( 'some_metabox', 'Связь с фильмами', 'movies_field', 'series' );
}
function movies_field() {
global $post;
$selected_movies = get_post_meta( $post->ID, '_movies', true );
$all_movies = get_posts( array(
'post_type' => 'movies',
'numberposts' => -1,
'orderby' => 'post_title',
'order' => 'ASC'
) );
?>
<input type="hidden" name="movies_nonce" value="<?php echo wp_create_nonce( basename( __FILE__ ) ); ?>" />
<table class="form-table">
<tr valign="top"><th scope="row">
<label for="movies">Фильмы</label></th>
<td><select multiple name="movies">
<?php foreach ( $all_movies as $movie ) : ?>
<option value="<?php echo $movie->ID; ?>"<?php echo (in_array( $movie->ID, $selected_movies )) ? ' selected="selected"' : ''; ?>><?php echo $movie->post_title; ?></option>
<?php endforeach; ?>
</select></td></tr>
</table>
}
add_action( 'save_post', 'save_movie_field' );
function save_movie_field( $post_id ) {
// выполняем только для типа записи series
if ( 'series' != get_post_type( $post_id ) )
return $post_id;
// проверяем nonce
if ( empty( $_POST['movies_nonce'] ) || !wp_verify_nonce( $_POST['movies_nonce'], basename( __FILE__ ) ) )
return $post_id;
// проверяем автосохранение
if ( defined( 'DOING_AUTOSAVE' ) && DOING_AUTOSAVE )
return $post_id;
// проверяем права пользователя
if ( !current_user_can( 'edit_post', $post_id ) )
return $post_id;
// сохраняем данные
update_post_meta( $post_id, '_movies', array_map( 'intval', $_POST['movies'] ) );
}
Затем, чтобы получить список связанных фильмов для записей сериалов:
$series = new WP_Query( array(
'post_type' => 'movies',
'post__in' => get_post_meta( $series_id, '_movies', true ),
'nopaging' => true
) );
if ( $series-> have_posts() ) { while ( $series->have_posts() ) {
$series->the_post();
?>
<li><a href="<?php the_permalink(); ?>"><?php the_title(); ?></a></li>
<?php
} }

Не создавая отдельную запись, можно ли добавить к этому создание постоянной ссылки из родительских/дочерних отношений? Например: http://domain.com/название-серии/название-фильма
?

@Xtremefaith это можно реализовать другим кодом. Я создал плагин для категорий. Возможно, вы сможете использовать его как пример. https://wordpress.org/plugins/hierarchical-urls/

Я рекомендую плагин Posts 2 Posts, который я недавно начал использовать.
Он позволяет создавать связи «многие ко многим» между записями и типами страниц, что означает, что вы можете связывать movies
с series
и любые другие пользовательские типы записей (CPT), которые вы создадите.
Этот плагин также позволяет создавать метаданные связей, что даст вам более детальный контроль при создании соединений. Он достаточно гибкий в использовании, предоставляя возможность управлять метабоксами в админке, типами связей и способами отображения связей на фронтенде. Наконец, он имеет хорошую документацию.

Я искал что-то подобное и пробовал различные решения. Должен сказать, что этот (Post 2 Post) был идеальным, возможно, это не то, что искал бы "не-программист", но если вам нужно что-то вроде библиотеки для использования в шаблоне, то это просто идеально, хорошо документировано, хорошо интегрировано, берите! ;)

Я сделал небольшой плагин для связей между записями, но https://wordpress.org/plugins/softmixt-relations

К сожалению, плагин Posts 2 Posts устарел и больше не поддерживается. Существует новый альтернативный плагин для этой цели — MB Relationships. Он вдохновлен P2P и предоставляет аналогичный API для создания связей между записями, терминами и пользователями.
MB Relationships по умолчанию поддерживает двунаправленные связи и использует собственную таблицу для хранения отношений (как P2P), что обеспечивает лучшую производительность (по сравнению с метаполями записей).
Стоит ознакомиться с этим плагином.
