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> ... @endforeachRoute 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]');
atau respon:
Jawaban
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.
- 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
297 Kontribusi 80 Poin
Login untuk gabung berdiskusi
Pertanyaan Lainnya
Top Kontributor
- @ahanafi
813 Kontribusi 551 Poin
- @Nandar
647 Kontribusi 204 Poin
- @dianarifr
642 Kontribusi 316 Poin
- @Saputroandhi
509 Kontribusi 162 Poin
- @dodipsitorus
412 Kontribusi 145 Poin