Salah id ketika melakukan deleting data di laravel

Saya sudah membuat CRUD menggunakan Framework Laravel 6.0. Saya memiliki masalah ketika suatu data dipilih untuk dihapus dengan parameter "id", id data yang saya pilih dengan id yang terhapus berbeda. Contoh : - di MySQL ada 3 data yang tersimpan yang memiliki id masing2: 29 , 30 , 31. - Ketika di view page tabel yg menampilkan data2 tersebut saya pilih salah satu data yg memiliki id= 31 untuk di delete, hasilnya salah yang terhapus malah data yg memiliki id= 29 - Yang selalu terpilih adalah id yang paling awal atau yang paling lama, misalkan hanya ada data A dengan id= 30 dan data B dengan id= 31. Ketika saya pilih data B untuk di delete di dalam page, maka yang terhapus adalah data A. Berikut source code yang saya gunakan: Function di Controller
function deleteClient($id)
    {
        //dd($client);
        $client = client::where('id','=',$id)->first();
        $client->delete();

        return redirect('/view-client');
    }
View Page
@foreach ($client as $c)
...
<a href="/{{ $c->id }}/delete" class="btn btn-danger" data-target="#delModal">Yes</a>
...
@endforeach
Route web
Route::group(['middleware'=>'auth'],function(){

    Route::get('/', function () {
        return view('home');
    });

    // clients
    Route::get('/input-client', '[email protected]');
    Route::get('/view-client', '[email protected]');
    Route::get('/{id}/edit', '[email protected]');
    Route::post('/input-client', '[email protected]');
    Route::get('/{id}/delete', '[email protected]');
    Route::put('/{id}/update', '[email protected]');
 
    ...

});


    //Authentication
    Route::get('/login', '[email protected]')->name('login');
    Route::post('/postlogin', '[email protected]');
    Route::get('/logout', '[email protected]');
avatar WildanB

@WildanB

2 Kontribusi 0 Poin


Jawaban

ke napa tida mengguunakan route /delete/{id} ?
avatar maszgalang

@maszgalang

297 Kontribusi 80 Poin


Halo maszgalang, Terimakasih atas kontribusinya, Apakah maksudnya seperti dibawah ini ?
Route::delete('/{id}/delete', '[email protected]');
Kalo seperti itu, saya sudah pernah mencobanya dan masih sama hasilnya.
avatar WildanB

@WildanB

2 Kontribusi 0 Poin

  • client::where('id')->first(); klo querynya seperti ini? - @maszgalang
  • Hasilnya error , karena delete() ini gabisa hapus id null - @WildanB


function deleteClient($id)
    {
        //dd($client);
        $client = client::find($id);
        $client->delete();

        return redirect('/view-client');
    }
coba pake itu
avatar maszgalang

@maszgalang

297 Kontribusi 80 Poin


Login untuk gabung berdiskusi