PHP-web框架Laravel-数据库(三)

2023-04-30 08:34:41 来源:腾讯云


(资料图)

三、模型关联

Laravel框架中的模型关联功能可以方便地实现数据库表之间的关联。在Laravel框架中,可以通过hasOne、hasMany、belongsTo、belongsToMany等方法来实现不同类型的关联。下面是一个hasMany关联的示例:

创建迁移文件

执行以下命令来创建articles和comments表:

php artisan make:migration create_articles_table --create=articlesphp artisan make:migration create_comments_table --create=comments

编写迁移代码

打开articles迁移文件,编写创建articles表的代码,如下所示:

public function up(){    Schema::create("articles", function (Blueprint $table) {        $table->id();        $table->string("title");        $table->text("content");        $table->timestamps();    });}

打开comments迁移文件,编写创建comments表的代码,如下所示:

public function up(){    Schema::create("comments", function (Blueprint $table) {        $table->id();        $table->unsignedBigInteger("article_id");        $table->foreign("article_id")->references("id")->on("articles")->onDelete("cascade");        $table->text("content");        $table->timestamps();    });}

上述代码创建了两个表,一个是articles表,一个是comments表。comments表中有一个article_id字段,该字段是外键,指向articles表中的id字段。

定义模型关联

在Laravel框架中,可以通过在模型中定义关联来实现不同表之间的关联。打开Article模型,定义hasMany关联,如下所示:

class Article extends Model{    public function comments()    {        return $this->hasMany(Comment::class);    }}

在Comment模型中,定义belongsTo关联,如下所示:

class Comment extends Model{    public function article()    {        return $this->belongsTo(Article::class);    }}

上述代码中,Article模型中的comments方法定义了hasMany关联,表示一个文章可以有多条评论;Comment模型中的article方法定义了belongsTo关联,表示一条评论属于一个文章。

使用模型关联

使用模型关联可以方便地获取关联的数据。下面是一个获取某篇文章的评论列表的示例:

$article = Article::find(1);$comments = $article->comments;

上述代码中,首先获取id为1的文章,然后通过$article->comments获取该文章的评论列表。

标签:

滚动