Title: Posts 2 Posts Relationships
Author: wp-centrics
Published: <strong>7 Tháng 7, 2021</strong>
Last modified: 19 Tháng 7, 2021

---

Tìm kiếm plugin

![](https://ps.w.org/posts-2-posts-relationships/assets/banner-772x250.png?rev=2560166)

Plugin này **chưa được cập nhật với 3 phiên bản mới nhất của WordPress**. Nó có 
thể không được hỗ trợ và bảo trì, và có thể xung đột với các phiên bản WordPress
mới nhất.

![](https://ps.w.org/posts-2-posts-relationships/assets/icon-256x256.gif?rev=2560166)

# Posts 2 Posts Relationships

 Bởi [wp-centrics](https://profiles.wordpress.org/wpcentrics/)

[Tải về](https://downloads.wordpress.org/plugin/posts-2-posts-relationships.zip)

 * [Chi tiết](https://vi.wordpress.org/plugins/posts-2-posts-relationships/#description)
 * [Đánh giá](https://vi.wordpress.org/plugins/posts-2-posts-relationships/#reviews)
 *  [Cài đặt](https://vi.wordpress.org/plugins/posts-2-posts-relationships/#installation)
 * [Nhà phát triển](https://vi.wordpress.org/plugins/posts-2-posts-relationships/#developers)

 [Hỗ trợ](https://wordpress.org/support/plugin/posts-2-posts-relationships/)

## Mô tả

This plugin allows you to create many-to-many relationships between posts of any
type: post, page, custom post types, etc.

Configure post 2 post connections easily in a friendly interface.

The new connection metaboxes will appear on the related post edition pages. Search
text, post type and term combo filter available as option for it.

Use the standard WP_Query() and get_posts() to get the related posts.

Solid-rock relationships: use his own database table, updated on post status change
and removed on post deletion.

#### Getting related: the WP_Query way

    ```
    // inside main loop, current post ID (p2p_rel_post_id) not needed, current post will be used if you don't set it:

    $args = array(
        'p2p_rel_key'        => 'prod_to_bars',  // This is your connection key name. Required.
        'p2p_rel_post_id'    => 1,               // The post ID. Inside main loop dont needed.
        'p2p_rel_direction'  => 'any',           // The connection direction. 'any' by default. Optional. Explained below. ( can be 'any' | 'from_to' | 'to_from' )

        // Of course, here you can add the standard WP arguments you need: post type, status, dates, pagination, etc.
    ); 

    // (at this point, as any other WP looping):

    // The Query 
    $the_query = new WP_Query( $args );

    // The Loop
    if ( $the_query->have_posts() ) {
        echo '<ul>';
        while ( $the_query->have_posts() ) {
            $the_query->the_post();
            echo '<li>' . get_the_title() . '</li>';
        }
        echo '</ul>';
    } else {
        // no posts found
        echo '<p>Nothing related</p>';
    }

    // Restore original Post Data 
    wp_reset_postdata();
    ```

#### Getting related: the get_posts() way

    ```
    // inside main loop, current post ID (p2p_rel_post_id) not needed, current post will be used if you don't set it:

    $args = array(
        'p2p_rel_key'        => 'prod_to_bars', // This is your connection key name. Required.
        'p2p_rel_post_id'    => 1,              // The post ID. Inside main loop dont needed
        'p2p_rel_direction'  => 'any',          // The connection direction. 'any' by default. Optional. Explained below. ( can be 'any' | 'from_to' | 'to_from' )
        'post_type'          => 'any',          // The filtered post types, can be an array. Optional. 'post' by default. (can be 'any' for all)
        'suppress_filters'   => false           // Required

        // Of course, here you can add the standard WP arguments you need: post type, status, dates, pagination, etc.
    ); 

    // (at this point, as any other WP looping):

    $rel_posts = get_posts ( $args );

    print_r( $rel_posts );
    ```

#### Getting related: getting it raw

    ```
    // inside main loop, current post ID (element_id) not needed, current post will be used if you don't set it:

    $args = array(
        'key'           => 'prod_to_bars',  // This is your connection key name. Required.
        'element_id'    => 1,               // The post ID. Inside main loop dont needed.
        'element_type'  => 'any',           // The filtered post types, can be an array. Optional. 'post' by default. (can be 'any' for all)
        'status'        => 'any'            // The filtered post status, can be an array. Optional. 'publish' by default. (can be 'any' for all)
        'direction'     => 'any',           // The connection direction. 'any' by default. Optional. Explained below. ( can be 'any' | 'from_to' | 'to_from' )
    ); 

    global $P2P_Relationships;
    $rel_posts = $P2P_Relationships->get_raw ( $args );

    // Only an array of related post IDs, not the posts objects.
    print_r ( $rel_posts ); 
    ```

#### The connection direction

By default, the connections are bidirectional (any). However, you can get related
posts only in one direction: ‘from_to’ or ‘to_from’.

You can do the same logic at interface level for your users in the backoffice: you
can setup your connection hidding the from metabox or the to metabox (UI mode setting).

## Ảnh màn hình

 * [[
 * Relations settings
 * [[
 * Relation settings (details)
 * [[
 * Relationships metaboxes on custom post type edition

## Cài đặt

See [Installing Plugins](https://codex.wordpress.org/Managing_Plugins#Installing_Plugins).

After activating it, go to Settings > P2P Relationships, and create your new post
2 post connections.

## Hỏi đáp

### Is this plugin an add-on for Advanced Custom Fields (ACF)?

No. This plugin is an stand-alone add-on for WordPress. However, it cover the gap
of ACF about many-to-many post connections, and can be used together.

### Where are the post connections stored?

This plugin store connecitons in his own table on database, instead of post meta.

This gives you a more efficient queries and a solid-rock connections consistency.

The DB table is named: {WP prefix}p2p_relationships

### Double metabox issue on post edition pages

If you need relationships between posts and posts, or products and products, etc.
Hide one of two metaboxes (UI mode setting) to avoid double metabox issue (FROM 
and TO same metaboxes relation in the same page).

## Đánh giá

![](https://secure.gravatar.com/avatar/373379ddec6a6ea94dba4a3cdcf6ce05693da8e8d353d06fa53faa57b4d99c0a?
s=60&d=retro&r=g)

### 󠀁[Amazing plugin!! Save a lot of Time in Development](https://wordpress.org/support/topic/amazing-plugin-save-a-lot-of-time-in-development/)󠁿

 [racmanuel.dev](https://profiles.wordpress.org/racmanuel/) 12 Tháng 4, 2022

Amazing plugin!! Save a lot of Time in Plugin and Theme Development

 [ Đọc tất cả 1 đánh giá ](https://wordpress.org/support/plugin/posts-2-posts-relationships/reviews/)

## Người đóng góp & Lập trình viên

“Posts 2 Posts Relationships” là mã nguồn mở. Những người sau đã đóng góp vào plugin
này.

Những người đóng góp

 *   [ wp-centrics ](https://profiles.wordpress.org/wpcentrics/)

“Posts 2 Posts Relationships” đã được dịch qua 1 ngôn ngữ. Cảm ơn [những người tham gia dịch](https://translate.wordpress.org/projects/wp-plugins/posts-2-posts-relationships/contributors)
vì đóng góp của họ.

[Dịch “Posts 2 Posts Relationships” sang ngôn ngữ của bạn.](https://translate.wordpress.org/projects/wp-plugins/posts-2-posts-relationships)

### Muốn tham gia phát triển?

[Duyệt code](https://plugins.trac.wordpress.org/browser/posts-2-posts-relationships/),
check out [SVN repository](https://plugins.svn.wordpress.org/posts-2-posts-relationships/),
hoặc theo dõi [nhật ký phát triển](https://plugins.trac.wordpress.org/log/posts-2-posts-relationships/)
qua [RSS](https://plugins.trac.wordpress.org/log/posts-2-posts-relationships/?limit=100&mode=stop_on_copy&format=rss).

## Nhật ký thay đổi

#### 1.0.0 – 2021-07-19

 * Checked for WordPress 5.8
 * Added warning and removal option for orphan relationships
 * Text-domain changed to the same as plugin slug: posts-2-posts-relationships

#### 0.0.2 – 2021-07-13

 * Solved admin pane layout broken issue

#### 0.0.1 – 2021-07-07

 * Hello world!

## Meta

 *  Phiên bản **1.0.0**
 *  Cập nhật lần cuối **5 năm trước**
 *  Số lượt cài đặt **40+**
 *  Phiên bản WordPress ** 4.7 hoặc cao hơn **
 *  Đã kiểm tra lên đến **5.8.13**
 *  Phiên bản PHP ** 5.5 hoặc cao hơn **
 *  Ngôn ngữ
 * [Catalan](https://ca.wordpress.org/plugins/posts-2-posts-relationships/) và [English (US)](https://wordpress.org/plugins/posts-2-posts-relationships/).
 *  [Dịch sang ngôn ngữ của bạn](https://translate.wordpress.org/projects/wp-plugins/posts-2-posts-relationships)
 * Thẻ
 * [custom post types](https://vi.wordpress.org/plugins/tags/custom-post-types/)
   [many-to-many](https://vi.wordpress.org/plugins/tags/many-to-many/)[posts 2 posts](https://vi.wordpress.org/plugins/tags/posts-2-posts/)
   [posts to posts](https://vi.wordpress.org/plugins/tags/posts-to-posts/)
 *  [Nâng cao](https://vi.wordpress.org/plugins/posts-2-posts-relationships/advanced/)

## Đánh giá

 5 trên 5 sao.

 *  [  1 5-star review     ](https://wordpress.org/support/plugin/posts-2-posts-relationships/reviews/?filter=5)
 *  [  0 4-star reviews     ](https://wordpress.org/support/plugin/posts-2-posts-relationships/reviews/?filter=4)
 *  [  0 3-star reviews     ](https://wordpress.org/support/plugin/posts-2-posts-relationships/reviews/?filter=3)
 *  [  0 2-star reviews     ](https://wordpress.org/support/plugin/posts-2-posts-relationships/reviews/?filter=2)
 *  [  0 1-star reviews     ](https://wordpress.org/support/plugin/posts-2-posts-relationships/reviews/?filter=1)

[Your review](https://wordpress.org/support/plugin/posts-2-posts-relationships/reviews/#new-post)

[Xem tất cả đánh giá](https://wordpress.org/support/plugin/posts-2-posts-relationships/reviews/)

## Những người đóng góp

 *   [ wp-centrics ](https://profiles.wordpress.org/wpcentrics/)

## Hỗ trợ

Có điều gì muốn nói? cần giúp đỡ?

 [Xem diễn đàn hỗ trợ](https://wordpress.org/support/plugin/posts-2-posts-relationships/)

## Ủng hộ

Bạn có muốn hỗ trợ vào sự phát triển của plugin này?

 [ Ủng hộ plugin này ](https://www.wp-centrics.com/)