一、关联模型(多对多)
1.1 多对多关系(抽象)
例:一篇文章可能有多个关键词,一个关键词可能被多个文章使用。
关键词表:
字段id | 主键 |
---|---|
字段keyword | 关键词 |
文章与关键词的关系表:
字段id | 主键 |
---|---|
字段article_id | 文章id |
字段key_id | 关键词id |
创建迁移文件:
php artisan make:migration create_keyword_table
php artisan make:migration create_relation_table
编写迁移文件的代码:
执行迁移php artisan migrate
创建填充器:
php artisan make:seeder KeywordAndRelationTableSeeder
编写填充器数据:
<?php
namespace Database\Seeders;
use Illuminate\Database\Seeder;
use DB;
class KeywordAndRelationTableSeeder extends Seeder
{
/**
* Run the database seeds.
*
* @return void
*/
public function run()
{
//关键词数据
DB::table('keyword') -> insert([
['keyword' => '搞笑'],
['keyword' => '文艺'],
['keyword' => '正片'],
['keyword' => '惊悚'],
['keyword' => '娱乐'],
['keyword' => '武术'],
]);
//关系表
DB::table('relation') -> insert([
[
'article_id' => rand(1,3),
'keyword_id' => rand(1,6)
],
[
'article_id' => rand(1,3),
'keyword_id' => rand(1,6)
],
[
'article_id' => rand(1,3),
'keyword_id' => rand(1,6)
],
[
'article_id' => rand(1,3),
'keyword_id' => rand(1,6)
],
]);
}
}
执行填充器:
php artisan db:seed --class=KeywordAndRelationTableSeeder
案例:查询出每个文章(主)下全部的关键词(从)
语法:
return $this -> belongsToMany(被关联模型的元素空间路径, 多对多模型的关系表名, 关系表中当前模型中的关系键,关系表中被关联模型的关系键)
上述语法提及到的关系键是指在关系表中的字段名。
创建关键词模型:
php artisan make:model Keyword
创建案例路由:
创建案例控制方法:
// 关系模型多对多
public function duoduiduo () {
// 查询文章
$data = Article::all();
// 循环
foreach ($data as $key => $value) {
// value是文章模型对象
echo '文章id:'.$value -> id .'<br/>';
echo '文章名称:'.$value -> article_name .'<br/>';
// 继续循环关键词
foreach($value -> rel_keyword as $k => $v) {
// $v是关键词的模型对象
echo '  ' . $v -> keyword .'<br/>';
}
echo '<hr/>';
}
}
效果:
在学习的php的路上,如果你觉得本文对你有所帮助的话,那就请关注点赞评论三连吧,谢谢,你的肯定是我写博的另一个支持。
转载:https://blog.csdn.net/weixin_44103733/article/details/115909161
查看评论