当我从前端提交表单数据时,我正在尝试创建一条新记录,而我正在努力地思考如何做到这一点。我一直在寻找例子,但还没有找到任何运气。因此,我正在提交新项目的数据,而我的项目与任务共享数据透视表关系。这是关系结构。
如果我提交数据以存储新参与并且我还想在同一时间存储新任务 ,我正在努力了解应该使用哪种方法完成这个。
我确实知道在填充数据透视表之前,我需要参与和任务存在。
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');
}
}
答案 0 :(得分:1)
您可以执行$task = Task::create(['user_id' => $request->get('assigned_to')])
。
接下来,您需要attach完成任务$engagement->tasks()->attach($task->id);
顺便说一句,您可以通过验证form request中的数据来稍微清理控制器。
接下来,您可以通过$engagement = Engagement::create($engagementRequest->validated())