Halo teman-teman semuanya, pada artikel sebelumnya kita telah belajar bagaimana cara mengedit dan memperbarui data di database. Kali ini, kita akan membahas cara menghapus data dari database di Laravel 12 menggunakan method DELETE.
Dengan memahami materi ini, teman-teman akan dapat mengimplementasikan fitur delete data dengan lebih optimal, termasuk menghapus gambar dari folder storage agar tidak membebani kapasitas server.
Selain itu, kita juga akan memastikan bahwa proses penghapusan berjalan aman dengan menampilkan konfirmasi sebelum data benar-benar dihapus.
Langkah 1 - Menambahkan Method destroy
di Controller
Untuk menghapus data dari database, kita perlu menambahkan method destroy
pada ProductController. Method ini akan menerima ID produk yang akan dihapus, mencari datanya, lalu menghapusnya.
Silakan buka file app/Http/Controllers/ProductController.php
dan ubah semua kode-nya menjadi seperti berikut ini.
app/Http/Controllers/ProductController.php
<?php
namespace App\Http\Controllers;
//import model product
use App\Models\Product;
//import return type View
use Illuminate\View\View;
//import return type redirectResponse
use Illuminate\Http\Request;
//import Http Request
use Illuminate\Http\RedirectResponse;
//import Facades Storage
use Illuminate\Support\Facades\Storage;
class ProductController extends Controller
{
/**
* index
*
* @return void
*/
public function index() : View
{
//get all products
$products = Product::latest()->paginate(10);
//render view with products
return view('products.index', compact('products'));
}
/**
* create
*
* @return View
*/
public function create(): View
{
return view('products.create');
}
/**
* store
*
* @param mixed $request
* @return RedirectResponse
*/
public function store(Request $request): RedirectResponse
{
//validate form
$request->validate([
'image' => 'required|image|mimes:jpeg,jpg,png|max:2048',
'title' => 'required|min:5',
'description' => 'required|min:10',
'price' => 'required|numeric',
'stock' => 'required|numeric'
]);
//upload image
$image = $request->file('image');
$image->storeAs('public/products', $image->hashName());
//create product
Product::create([
'image' => $image->hashName(),
'title' => $request->title,
'description' => $request->description,
'price' => $request->price,
'stock' => $request->stock
]);
//redirect to index
return redirect()->route('products.index')->with(['success' => 'Data Berhasil Disimpan!']);
}
/**
* show
*
* @param mixed $id
* @return View
*/
public function show(string $id): View
{
//get product by ID
$product = Product::findOrFail($id);
//render view with product
return view('products.show', compact('product'));
}
/**
* edit
*
* @param mixed $id
* @return View
*/
public function edit(string $id): View
{
//get product by ID
$product = Product::findOrFail($id);
//render view with product
return view('products.edit', compact('product'));
}
/**
* update
*
* @param mixed $request
* @param mixed $id
* @return RedirectResponse
*/
public function update(Request $request, $id): RedirectResponse
{
//validate form
$request->validate([
'image' => 'image|mimes:jpeg,jpg,png|max:2048',
'title' => 'required|min:5',
'description' => 'required|min:10',
'price' => 'required|numeric',
'stock' => 'required|numeric'
]);
//get product by ID
$product = Product::findOrFail($id);
//check if image is uploaded
if ($request->hasFile('image')) {
//delete old image
Storage::delete('products/'.$product->image);
//upload new image
$image = $request->file('image');
$image->storeAs('products', $image->hashName());
//update product with new image
$product->update([
'image' => $image->hashName(),
'title' => $request->title,
'description' => $request->description,
'price' => $request->price,
'stock' => $request->stock
]);
} else {
//update product without image
$product->update([
'title' => $request->title,
'description' => $request->description,
'price' => $request->price,
'stock' => $request->stock
]);
}
//redirect to index
return redirect()->route('products.index')->with(['success' => 'Data Berhasil Diubah!']);
}
/**
* destroy
*
* @param mixed $id
* @return RedirectResponse
*/
public function destroy($id): RedirectResponse
{
//get product by ID
$product = Product::findOrFail($id);
//delete image
Storage::delete('products/'. $product->image);
//delete product
$product->delete();
//redirect to index
return redirect()->route('products.index')->with(['success' => 'Data Berhasil Dihapus!']);
}
}
Dari perubahan kode di atas, kita menambahkan method baru dengan nama destroy
dan pada parameternya ita berikan $id
, yang nanti nilainya akn diambil dari URL browser.
public function destroy($id): RedirectResponse
{
//...
}
Di dalam method tersebut, pertama, kita akan mendari data product berdasarkan ID.
//get product by ID
$product = Product::findOrFail($id);
Jika sudah ditemukan, maka kita akan melakukan delete gambar.
//delete image
Storage::delete('products/'. $product->image);
Setelah gambar berhasil dihapus, langkah berikutnya adalah menghapus data dari database.
//delete product
$product->delete();
kemudian kita redirect ke dalam route yang bernama products.index
dengan memberikan session flash data.
//redirect to index
return redirect()->route('products.index')->with(['success' => 'Data Berhasil Dihapus!']);
Langkah 2 - Uji Coba Delete Data Product
Silahkan teman-teman klik button DELETE
di salah satu data yang dimiliki, jika berhasil maka akan menampilkan alert konfirmasi. Kurang lebih seperti berikut ini.

Jika teman-teman klik OK
, maka data akan dihapus dan teman-teman akan mendapatkan hasil seperti berikut ini.

Kesimpulan
Pada artikel ini, kita telah mempelajari cara menghapus data dari database di Laravel 12 menggunakan method DELETE. Selain menghapus data dari database, kita juga memastikan bahwa file gambar terkait turut dihapus dari folder storage agar tidak membebani server.
Jika ada kendala atau pertanyaan terkait materi Laravel 12, silakan tanyakan melalui kolom komentar di setiap artikel atau bergabung dalam grup Telegram SantriKoding untuk berdiskusi lebih lanjut dengan komunitas.
Terima Kasih