PHP-web框架Laravel-数据库(三)
发布时间:2023-04-30 13:23:50
来源:腾讯云
(相关资料图)
三、模型关联
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获取该文章的评论列表。