Laravel:编辑数据后更新数据库时出错

Laravel :error when updating the database after editing data

我有两个 tables table "technician" 和 table "user" 一对一连接,我有一个表格可以用来编辑技术人员信息。当我保存更改时出现错误并且更新没有 work.Here 是我的表单我的代码和错误的屏幕截图提前谢谢你。

route.php

Route::get('/technicien/{id}/edit', 'TechnicienController@edit');
Route::patch('/technicien/{id}', 'TechnicienController@update')-
>name('technicien.update');

edit.php

@extends('Layouts/app')
@extends('Layouts.master')
@section('content')
<div class="container">
    <div class="row">
        <div class="col-md-10">
            <h1>Modifier Technicien</h1>
        <form action="{{ route('technicien.update', $moyenne_avis->id , $actif->id , $user->nom , $user->prenom ,$user->email ) }}" method="update">
        {{csrf_field()}}
        {{ method_field('PATCH') }}


             <div class="form-group">
            <label for="nom">Nom</label>
            <input id="nom" type="text" class="form-control" name="user[nom]" value="{{$user->nom}}" >
        </div>
        <div class="form-group">
            <label for="prenom">Prenom</label>
            <input id="prenom" type="text" class="form-control" name="user[prenom]" value="{{$user->prenom}}" >
        </div>
        <div class="form-group">
            <label for="prenom">Email</label>
            <input id="prenom" type="text" class="form-control" name="user[email]" value="{{$user->email}}" >
        </div>

        <div class="form-group">
            <label for="">moyenne Avis</label>
            <input type="text"  name="moyenne_avis" class="form-control" value ="{{$moyenne_avis->moyenne_avis}}" >
        </div>
        <div class="form-group">
            <label for="">Etat Technicien</label>
            <input type="text"  name="actif" class="form-control" value ="{{$moyenne_avis->actif}}" >
        </div>

        <div class="form-group">
            <input type="submit" value="enregistrer" class="form-control btn btn-primary">
        </div>
            </div>




        </form>
    </div>
</div>
@endsection

controller1.php

public function edit($id)
{
    $technicien=technicien::find($id);
    $user = $technicien->user;
    return view('technicien.edit',['moyenne_avis'=>$technicien],
    ['actif'=>$technicien],['user_id'=>$technicien])->with('user',$user);
}

controller2.php

public function update(Request $request, $id)
{
    // do some request validation

    $technicien=technicien::find($id);
    $technicien->update($request->all());
    $technicien->user->update($request->get('user'));
    return redirect('technicien');
}

您传递的参数过多,而在您的路由中您只采用了一个参数!

我认为您在视图中只需要一个参数,即技术人员 ID,它将在您的控制器查询中找到记录!

您可以尝试按照代码从表单中删除不可用的参数:

<form action="{{ route('technicien.update', $moyenne_avis->id ) }}" method="POST">

您的路线如下:

Route::get('/technicien/{id}/edit', 'TechnicienController@edit');
Route::post('/technicien/{id}', 'TechnicienController@update')->name('technicien.update');

希望对您有所帮助!