laravel 多对多关联模型CURD详解

原文链接

https://blog.csdn.net/kunpeng1987/article/details/82148121

 

 

1、laravel官方文档中给出了一种用户-角色(User-Role)关系的例子。在这个例子中,一个用户可能与多个角色对应,反过来同理,一个角色也可能对应多个用户。官方说的比较简单,这里详细介绍一下。

一个用户可以有多个不同的角色;
一个角色会拥有各种不同的用户;
现在已最简单的数据解构为例进行说明:

角色数据表roles :id、name
用户数据表users : id、name
角色-用户数据表role_user : role_id、user_id
在这个场景中,role_user数据表,就是我们所要说明的pivot表(透视表,及本文的主要说明对象),首先做一下几点说明:

关联表名称:关联表的命名满足一下两点:①需包含相关联的单表的表名;②以下划线_链接相关联表名;③通常以字母先后顺序来确定相关联表名的先后顺序;如本例中关联表可叫做role_user而不是user_role或者其他名字;
创建关联表:创建关联表,一般常见一个简单的命令php artisan make:migration或php artisan make:migration:pivot.
关联表键名:通常情况下,每个关联表需要有两个外键字段,每个外键对应一张外联表,在我们的商店-商品场景中,这两个外键分别是role_id、user_id;当然如果你喜欢你也可以添加更多的字段,但那种情况下,你需要添加更多的关系,这种情况我们稍后会进一步说明。
 

2、创建数据表

 

① php artisan make:model --migration Model/Roles

修改文件如下:

Schema::create('roles', function (Blueprint $table) {
 
    $table->increments('id');
 
    $table->string('name');
 
    $table->timestamps();
 
});
 

② php artisan make:model --migration Model/Users

修改文件如下:

Schema::create('users', function (Blueprint $table) {
 
    $table->increments('id');
 
    $table->string('name');
 
    $table->timestamps();
 
});
③ php artisan make:migration:pivot roles users

注意:使用这条命令需要安装扩展包

composer require laracasts/generators --dev

接下来注册服务提供者,由于我们只需要在本地开发环境使用这个扩展包,而如果注册到config/app.php的providers数组,则会导致生产环境也会加载,所以我们只需在app/Providers/AppServiceProvider.php中注册它即可:

public function register()
 
{
 
    if ($this->app->environment() == 'local') {
 
        $this->app->register('Laracasts\Generators\GeneratorsServiceProvider');
 
    }
 
}
④ 执行命令迁徙数据库

php artisan migrate

⑤ 修改User.php 模型

class User extends Model
 
{
 
    //指定批量更新字段
 
    protected $fillable = ['name'];
 
 
 
    public function roles()
 
    {
 
        //return $this->belongsToMany(Role::class);
 
        //指定自定义命名生成关联表的键名,外键等
 
        return $this->belongsToMany(Role::class,'role_user','user_id','role_id');
 
    }
 
}
 

3、多对多关联数据的管理

①、插入

$user = User::create($users);
 
$user->roles()->attach($role_ids);
②、查询

$user = User::find($id);
 
$user->roles;
③ 、删除

$user = User::findOrFail($id);
 
$user->roles()->detach();
 
$user->delete();
这里用的是资源控制器,控制器完整代码如下:

<?php
 
namespace App\Http\Controllers;
 
use App\Http\Requests\UserRequest;
use App\Model\User;
use Illuminate\Database\QueryException;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\DB;
 
class UserController extends Controller
{
    /**
     * Display a listing of the resource.
     *
     * @return \Illuminate\Http\Response
     */
    public function index()
    {
        $users = User::get();
        foreach ($users as $user) {
            if ($user) {
                $user->roles;
            }
        }
        return response()->json([
            'message' => '请求成功',
            'data' => $users ?: []
        ], 200);
    }
 
    /**
     * Show the form for creating a new resource.
     *
     * @return \Illuminate\Http\Response
     */
    public function create()
    {
        //
    }
 
    /**
     * Store a newly created resource in storage.
     *
     * @param  \Illuminate\Http\Request $request
     * @return \Illuminate\Http\Response
     */
    public function store(UserRequest $request)
    {
        $users['name'] = $request->get('name');
        $role_ids = $request->get('role_id');
        DB::beginTransaction();
        try{
            $user = User::create($users);
            $user->roles()->attach($role_ids);
 
            DB::commit();
            return response()->json([
                'message' => '新增成功',
                'data' => $user
            ], 200);
        }catch (\Exception $e){
            DB::rollBack();
            return response()->json([
                'message' => '新增失败',
            ], 400);
        }
    }
 
    /**
     * Display the specified resource.
     *
     * @param  int $id
     * @return \Illuminate\Http\Response
     */
    public function show($id)
    {
        $user = User::find($id);
        if($user) {
            $user->roles;
        }
 
        return response()->json([
            'message' => '请求成功',
            'data' => $user ?: []
        ], 200);
 
    }
 
    /**
     * Show the form for editing the specified resource.
     *
     * @param  int $id
     * @return \Illuminate\Http\Response
     */
    public function edit($id)
    {
        //
    }
 
    /**
     * Update the specified resource in storage.
     *
     * @param  \Illuminate\Http\Request $request
     * @param  int $id
     * @return \Illuminate\Http\Response
     */
    public function update(Request $request, $id)
    {
        $user_name['name'] = $request->get('name');
        $role_ids = $request->get('role_id');
        DB::beginTransaction();
        try {
            $user = User::findOrFail($id);
            $user->update($user_name);
            $user->roles()->detach();//先删除关系
            $user->roles()->attach($role_ids);
            DB::commit();
            return response()->json([
                'message' => '更新成功',
                'data' => $id
            ], 200);
        } catch (\Exception $e) {
            DB::rollBack();
            return response()->json([
                'message' => '更新失败',
            ], 400);
        }
    }
 
    /**
     * Remove the specified resource from storage.
     *
     * @param  int $id
     * @return \Illuminate\Http\Response
     */
    public function destroy($id)
    {
        DB::beginTransaction();
        try {
            $user = User::findOrFail($id);
            $user->roles()->detach();
            $user->delete();
            DB::commit();
            return response()->json([
                'message' => '删除成功',
                'data' => $id
            ], 200);
        } catch (\Exception $e) {
            DB::rollBack();
            return response()->json([
                'message' => '删除失败',
            ], 400);
        }
    }
}
 
 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值