Home > PHP Framework > Laravel > Laravel development: How to implement polymorphic associations using Laravel Eloquent?

Laravel development: How to implement polymorphic associations using Laravel Eloquent?

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
Release: 2023-06-13 16:41:52
Original
1749 people have browsed it

Laravel Development: How to use Laravel Eloquent to implement polymorphic associations?

Polymorphic association is an important feature of Laravel Eloquent, which allows one model to establish relationships with multiple different models. In practical applications, processing different types of data is relatively simple and efficient, especially in database design. In this article, we will discuss how to implement polymorphic associations using Laravel Eloquent.

1. What is polymorphic association?

Polymorphic association refers to the establishment of an association relationship between a model and multiple different models, which can be regarded as a reference to a general category. It can bring convenience to many applications, such as:

  1. Image, audio and video models can all establish polymorphic associations with comment models, so that comments can be applied to multiple data types.
  2. Users can establish polymorphic associations with comment models and be applied to a variety of data types, such as articles, pictures, videos, etc.
  3. The order model can establish a polymorphic association with the delivery address model, so that orders can be delivered to multiple address types, such as homes, companies, outlets, etc.

2. Methods to implement polymorphic association

Let’s take a look at how to use Laravel Eloquent to implement polymorphic association.

First of all, we need to consider the design of the data table. We need to create an intermediate table to store polymorphic relationships between models. This table should contain the following columns:

  1. id: table primary key ID;
  2. target_type: type name of the target model;
  3. target_id: ID of the target model;
  4. source_type: The type name of the source model;
  5. source_id: The ID of the source model.

The following is an example of a database migration file:

<?php

use IlluminateDatabaseMigrationsMigration;
use IlluminateDatabaseSchemaBlueprint;
use IlluminateSupportFacadesSchema;

class CreateCommentsTable extends Migration
{
    /**
     * Run the migrations.
     *
     * @return void
     */
    public function up()
    {
        Schema::create('comments', function (Blueprint $table) {
            $table->id();
            $table->morphs('commentable');
            $table->text('content');
            $table->timestamps();
        });

        Schema::create('votes', function (Blueprint $table) {
            $table->id();
            $table->unsignedBigInteger('user_id');
            $table->unsignedBigInteger('voteable_id');
            $table->string('voteable_type');
            $table->enum('type', ['up', 'down']);
            $table->timestamps();
        });
    }

    /**
     * Reverse the migrations.
     *
     * @return void
     */
    public function down()
    {
        Schema::dropIfExists('comments');
        Schema::dropIfExists('votes');
    }
}
Copy after login

In the above migration file, we created two new tables: comments and votes.

The comments table contains basic information about the comment model, and uses the morphs() method to implement polymorphic association pointing. The votes table is similar, using voteable_id and voteable_type fields to implement polymorphic association.

Next, we need to define the association relationship in the Eloquent model.

Comment model:

<?php

namespace AppModels;

use IlluminateDatabaseEloquentFactoriesHasFactory;
use IlluminateDatabaseEloquentModel;

class Comment extends Model
{
    use HasFactory;

    public function commentable()
    {
        return $this->morphTo();
    }

    public function votes()
    {
        return $this->morphMany(Vote::class, 'voteable');
    }
}
Copy after login

Vote model:

<?php

namespace AppModels;

use IlluminateDatabaseEloquentFactoriesHasFactory;
use IlluminateDatabaseEloquentModel;

class Vote extends Model
{
    use HasFactory;

    public function voteable()
    {
        return $this->morphTo();
    }

    public function user()
    {
        return $this->belongsTo(User::class);
    }
}
Copy after login

The above code will define polymorphic relationships for the Comment model and the Vote model respectively. In the Comment model, we use the morphTo() method to define the polymorphic association to the comment, and in the Vote model, we use the morphMany() method to define the polymorphic association to the comment.

3. Use polymorphic association

Let us see how to use polymorphic association.

Create a comment:

$article = Article::find(1);

$comment = $article->comments()->create([
    'content' => 'This is a comment',
]);
Copy after login

Get votes for comments:

$votes = $comment->votes;
Copy after login

Get comments for articles:

$comments = $article->comments;
Copy after login

Votes:

$comment->votes()->create([
    'user_id' => 1,
    'type' => 'up',
]);
Copy after login

Above The code example demonstrates the basic use of polymorphic relationships, and you can find more details about this feature in the Laravel Eloquent documentation.

Summary

Polymorphic association is one of the important features of Laravel Eloquent, which allows one model to establish relationships with multiple different models. Very useful in database design and application development. When using Laravel Eloquent to implement polymorphic relationships, you need to design the intermediate table of the relationship and define the relationship in the Eloquent model. We can use the morphTo() and morphMany() methods to implement polymorphic relationships.

The above is the detailed content of Laravel development: How to implement polymorphic associations using Laravel Eloquent?. For more information, please follow other related articles on the PHP Chinese website!

source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Latest Issues
Composer cannot install laravel
From 1970-01-01 08:00:00
0
0
0
Laravel Space/laravel-backup cannot be installed
From 1970-01-01 08:00:00
0
0
0
Laravel 5.1 Login laravel comes with it No more
From 1970-01-01 08:00:00
0
0
0
Why thinkphp has better performance than laravel?
From 1970-01-01 08:00:00
0
0
0
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template