通过Laravel中的数据透视表存储新记录

时间:2018-10-15 19:27:51

标签: laravel eloquent

当我从前端提交表单数据时,我正在尝试创建一条新记录,而我正在努力地思考如何做到这一点。我一直在寻找例子,但还没有找到任何运气。因此,我正在提交新项目的数据,而我的项目与任务共享数据透视表关系。这是关系结构。

  1. 用户具有许多任务
  2. 任务属于用户
  3. 客户有很多参与
  4. 参与度属于客户
  5. 任务属于许多参与(当然反之亦然)

如果我提交数据以存储新参与并且我还想在同一时间存储新任务 ,我正在努力了解应该使用哪种方法完成这个。

我确实知道在填充数据透视表之前,我需要参与和任务存在。

EngagementsController.php (用于存储新的参与)

public function store(Request $request)
{
    $data = $request->validate([
        'client_id' => 'required|integer',
        'return_type' => 'required|string',
        'year' => 'required|string',
        'status' => 'required|string',
        'assigned_to' => 'required|string',
        'done' => 'required|boolean'
    ]);

    $engagement = Engagement::create([
        'client_id' => $request->client_id,
        'return_type' => $request->return_type,
        'year' => $request->year,
        'assigned_to' => $request->assigned_to,
        'status' => $request->status,
        'done' => $request->done,
    ]);

    return response($engagement, 201);
}

运行$engagement = Engagement之后,我想知道我是否可以同时使用 Engagement Task assigned_to字段中的数据这样吗?

$engagement = Engagement::create([
    'client_id' => $request->client_id,
    'return_type' => $request->return_type,
    'year' => $request->year,
    'assigned_to' => $request->assigned_to,
    'status' => $request->status,
    'done' => $request->done,
]);

$data = $request->assigned_to;
$task->tasks()->create($data);

参与模式

class Engagement extends Model
{
    protected $fillable =
    [
        'client_id',
        'return_type',
        'year',
        'assigned_to',
        'status',
    ];
    public function client() 
    {
        return $this->belongsTo('App\Client');
    }

    public function tasks()
    {
        return $this->belongsToMany('App\Task', 'engagement_task', 'engagement_id', 'task_id');
    }

    public function questions()
    {
        return $this->hasMany('App\Question');
    }

}

任务模型

class Task extends Model
{
    protected $fillable = ['user_id'];

    public function user()
    {
        return $this->belongsTo('App\User');
    }

    public function engagements()
    {
        return $this->belongsToMany('App\Engagement', 'engagement_task', 'task_id', 'engagement_id');
    }
}

1 个答案:

答案 0 :(得分:1)

您可以执行$task = Task::create(['user_id' => $request->get('assigned_to')])

接下来,您需要attach完成任务$engagement->tasks()->attach($task->id);

顺便说一句,您可以通过验证form request中的数据来稍微清理控制器。

接下来,您可以通过$engagement = Engagement::create($engagementRequest->validated())

建立参与度