在实际开发中多对多的开发还是比较常见的

1.1首先由migrate来创建表(文章表)

laravel实现多对多的分析-LMLPHP

1.2同理创建标签表

laravel实现多对多的分析-LMLPHP

1.3这是 我会的到如下结果:

laravel实现多对多的分析-LMLPHP

2.1在数据迁移表contents中添加几个字段

 public function up()
{
Schema::create('contents', function (Blueprint $table) {
$table->increments('id'); $table->string('title');
$table->text('body'); $table->timestamps();
});
}

2.2在数据迁移表tag中添加如下字段:

public function up()
{
Schema::create('tags', function (Blueprint $table) {
$table->increments('id');
$table->string('name');
$table->timestamps();
}); Schema::create('content_tag', function (Blueprint $table) {
$table->increments('id');
$table->string('name');
$table->integer('content_id')->unsigned()->index();
$table->integer('tag_id')->unsigned()->index(); //设置外键
$table->foreign('content_id')->references('id')->on('contents')->onDelete('cascade');
$table->foreign('tag_id')->references('id')->on('tags')->onDelete('cascade');
$table->timestamps();
});
}

3.3这时运行如下的artisan命令

php artisan migrate

 在数据库表中可以看到如下表

laravel实现多对多的分析-LMLPHP

这时就在两个模型中各添加一个方法

 //在Content模型中 添加

 public function tags()
{
return $this->belongsToMany(Tag::class);
} //在Tag模型中 添加
public function contents()
{
return $this->belongsToMany(Content::class);
}

现在进入测试阶段代码如下

//向各表中添加20条数据

factory(Content::class,20)->create();

factory(Tag::class,20)->create();

结果如下:

laravel实现多对多的分析-LMLPHP

最后几步配置路由如下

Route::get('/', function () {
$content = \App\Content::find(3);
//在content_tag表中添加tag标签为3和content表中id为3的数据
$content_tag = $content->tags()->attach(3); //进行删除数据
// $content_tag = $content->tags()->detach(3);
dd($content_tag);
return view('welcome');
});

紧接着启动服务器 

php artisan  serve

 测试结果:在表中的数据

laravel实现多对多的分析-LMLPHP

删除之后的结果

laravel实现多对多的分析-LMLPHP

 

05-11 16:55