Skip to content

emka.web.id

menulis pengetahuan – merekam peradaban

Menu
  • Home
  • Tutorial
  • Search
Menu

Tutorial CRUD PHP Sederhana Terbaru 2024

Posted on October 14, 2024

Membuat aplikasi web dinamis sering kali melibatkan interaksi dengan database. Salah satu dasar dalam pengembangan web adalah kemampuan untuk melakukan operasi CRUD: Create, Read, Update, dan Delete. Tutorial ini akan memandu Anda melalui operasi CRUD PHP inti, membantu Anda memahami bagaimana mengelola data secara efektif dalam aplikasi Anda. Baik Anda membangun blog sederhana atau aplikasi web kompleks, menguasai operasi ini akan sangat penting dalam perjalanan pengembangan Anda.

Persiapan

Sebelum menyelami operasi CRUD, pastikan Anda memiliki pemahaman dasar tentang hal berikut:

  • HTML dan CSS: Untuk membuat antarmuka pengguna.
  • PHP: Pengetahuan tentang konsep PHP inti.
  • MySQL: Pemahaman dasar tentang database relasional dan query SQL.
  • XAMPP atau MAMP: Pengaturan server lokal untuk menjalankan skrip PHP Anda.

Menetapkan Lingkungan Anda

Instal XAMPP atau MAMP: Ini akan membantu Anda menjalankan PHP dan MySQL di mesin lokal Anda.
Buat Database: Buka phpMyAdmin dan buat database bernama crud_demo. Di dalam database ini, buat tabel bernama users dengan struktur berikut:

CREATE TABLE users (
id INT AUTO_INCREMENT PRIMARY KEY,
name VARCHAR(100) NOT NULL,
email VARCHAR(100) NOT NULL UNIQUE,
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);

Tabel users ini akan menyimpan data untuk operasi CRUD kita.

Membuat Skrip PHP untuk Operasi CRUD

  1. Koneksi Database
    Mulailah dengan membuat file config.php untuk menangani koneksi database.
<?php
$host = 'localhost';
$db_name = 'crud_demo';
$username = 'root'; // Ubah jika nama pengguna MySQL Anda berbeda
$password = ''; // Ubah jika Anda telah menetapkan kata sandi
try {
$conn = new PDO("mysql:host=$host;dbname=$db_name", $username, $password);
$conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
} catch (PDOException $e) {
echo "Connection failed: " . $e->getMessage();
}
?>

  1. Membuat Data (Insert)
    Selanjutnya, buat file create.php untuk memasukkan data ke dalam tabel users.
<?php
include 'config.php';
if ($_SERVER['REQUEST_METHOD'] == 'POST') {
$name = $_POST['name'];
$email = $_POST['email'];
$stmt = $conn->prepare("INSERT INTO users (name, email) VALUES (:name, :email)");
$stmt->bindParam(':name', $name);
$stmt->bindParam(':email', $email);
if ($stmt->execute()) {
echo "New user created successfully.";
} else {
echo "Error creating user.";
}
}
?>

<form method="POST">
Name: <input type="text" name="name" required>
Email: <input type="email" name="email" required>
<input type="submit" value="Create User">
</form>

  1. Membaca Data (Select)
    Buat file read.php untuk menampilkan semua pengguna di tabel users.
<?php
include 'config.php';
$stmt = $conn->prepare("SELECT * FROM users");
$stmt->execute();
$users = $stmt->fetchAll(PDO::FETCH_ASSOC);
?>

<table border="1">
<tr>
<th>ID</th>
<th>Name</th>
<th>Email</th>
<th>Actions</th>
</tr>
<?php foreach ($users as $user): ?>
<tr>
<td><?php echo $user['id']; ?></td>
<td><?php echo $user['name']; ?></td>
<td><?php echo $user['email']; ?></td>
<td>
<a href="update.php?id=<?php echo $user['id']; ?>">Edit</a>
<a href="delete.php?id=<?php echo $user['id']; ?>">Delete</a>
</td>
</tr>
<?php endforeach; ?>
</table>

  1. Memperbarui Data
    Sekarang, buat file update.php untuk memperbarui informasi pengguna.
<?php
include 'config.php';
$id = $_GET['id'];
if ($_SERVER['REQUEST_METHOD'] == 'POST') {
$name = $_POST['name'];
$email = $_POST['email'];
$stmt = $conn->prepare("UPDATE users SET name = :name, email = :email WHERE id = :id");
$stmt->bindParam(':name', $name);
$stmt->bindParam(':email', $email);
$stmt->bindParam(':id', $id);
if ($stmt->execute()) {
echo "User updated successfully.";
header("Location: read.php");
exit();
} else {
echo "Error updating user.";
}
} else {
$stmt = $conn->prepare("SELECT * FROM users WHERE id = :id");
$stmt->bindParam(':id', $id);
$stmt->execute();
$user = $stmt->fetch(PDO::FETCH_ASSOC);
}
?>

<form method="POST">
Name: <input type="text" name="name" value="<?php echo $user['name']; ?>" required>
Email: <input type="email" name="email" value="<?php echo $user['email']; ?>" required>
<input type="submit" value="Update User">
</form>

  1. Menghapus Data
    Terakhir, buat file delete.php untuk menangani penghapusan pengguna.
<?php
include 'config.php';
$id = $_GET['id'];
$stmt = $conn->prepare("DELETE FROM users WHERE id = :id");
$stmt->bindParam(':id', $id);
if ($stmt->execute()) {
echo "User deleted successfully.";
header("Location: read.php");
exit();
} else {
echo "Error deleting user.";
}
?>

Memahami Operasi CRUD

  • Create: Operasi Create memungkinkan Anda menambahkan catatan baru ke database. Dalam contoh kita, kita menggunakan form HTML untuk mengumpulkan input pengguna dan metode PDO prepare dan execute untuk memasukkan data dengan aman.
  • Read: Operasi Read mengambil dan menampilkan catatan dari database. Kita menggunakan query SQL SELECT untuk mengambil data pengguna, dan kita memformatnya ke dalam tabel HTML untuk dilihat dengan mudah.
  • Update: Operasi Update memodifikasi catatan yang ada berdasarkan input pengguna. Kita mengambil data saat ini untuk pengguna tertentu, menampilkannya dalam form, dan memperbarui catatan menggunakan permintaan POST.
  • Delete: Operasi Delete menghapus catatan dari database. Dengan meneruskan ID pengguna melalui parameter URL, kita dapat menjalankan pernyataan DELETE untuk menghapus pengguna yang ditentukan.

Praktik Terbaik untuk Operasi CRUD PHP

  • Gunakan Pernyataan yang Dipersiapkan: Selalu gunakan pernyataan yang dipersiapkan untuk melindungi dari injeksi SQL.
  • Validasi Input Pengguna: Terapkan validasi sisi server untuk input pengguna untuk memastikan integritas data.
  • Terapkan Penanganan Kesalahan: Gunakan blok try-catch untuk menangani kesalahan potensial dengan anggun.
  • Organisir Kode Anda: Jaga kode Anda tetap terorganisir dengan memisahkan kekhawatiran (misalnya, koneksi database, logika bisnis, dan presentasi).
  • Ikuti Praktik Terbaik Keamanan: Bersihkan input, hash kata sandi, dan amankan aplikasi Anda dari kerentanan umum.

Kesimpulan

Dalam tutorial ini, kita telah membahas operasi CRUD inti PHP yang penting, menunjukkan cara membuat, membaca, memperbarui, dan menghapus catatan dalam database MySQL. Dengan memahami operasi dasar ini, Anda akan siap membangun aplikasi web dinamis.

Ingat bahwa menguasai operasi CRUD hanyalah permulaan. Saat Anda maju dalam perjalanan PHP Anda, jelajahi konsep tambahan seperti integrasi AJAX, validasi data, dan tindakan keamanan untuk meningkatkan aplikasi Anda lebih lanjut.

Dengan latihan dan kesabaran, Anda akan dapat mengimplementasikan fungsionalitas kompleks dan membuat aplikasi web yang kuat yang memenuhi berbagai kebutuhan pengguna. Selamat coding!

Terbaru

  • Samsung Akan Luncurkan One UI 8.5 dengan Inspirasi ‘Liquid Glass’ yang Memukau
  • XBox Game Pass PC Tidak Bisa Address GPU ke Game
  • Your Pocket-Sized Doctors: 3 Health Apps Changing the Game on Android and iOS
  • Waymo Bawa Teknologi ‘Liquid Glass’ untuk Mobil Otonom
  • Rumor Google Akan Update UI Besar-besaran Desember 2025
  • Gemini Akan Masuk di Android Auto, Mobil Jadi Lebih Smart!
  • OpenAI Bantah Rencana Pasang Iklan di ChatGPT Berlangganan
  • Kenapa Komputer Sangat Panas Saat Gunakan Fitur Virtualisasi Hyper-V?
  • Apa itu Bug React2Shell? Sudah Serang Lebih dari 30 Organisasi dan 77.000 IP Address
  • Google Store Black Friday 2025: Penawaran Spesial untuk Pixel, Nest, dan Lainnya!
  • Boxville 2 Gratis di Playstore, Plus Diskon Lainnya!
  • Cara Atasi Masalah Pembacaan Suara (Read Aloud) di Windows Copilot Tidak Berfungsi
  • Kementerian Kesehatan Inggris Akui Data Breach, Akibat Zero-day Oracle DB?
  • Google Akan Perkenalkan Autofill Google Wallet di Chrome untuk Pembayaran Lebih Mudah
  • Google Pixel Akan Perkenalkan Launcher Device Search Baru, Lebih Cepat dan Pintar
  • Hacker Serang Bug VPN di ArrayOS AG untuk Menanam Web Shell
  • Cara Menonaktifkan Error “ITS Almost time to restart in Windows”
  • Google Fi Mendukung Panggilan Telepon RCS Melalui Web, Lebih Mudah dan Efisien
  • Data Breach Marquis: Hajar Lebih Dari 74 Bank dan Koperasi AS
  • Google Search Akan Adopsi ‘Continuous Circle’ untuk Hasil Pencarian Terjemahan, Lebih Cerdas dan Kontekstual
  • Rusia Memblokir Roblox Karena Distribusi ‘Propaganda LGBT’
  • Google Gemini Redesain Web Total di Desember 2025, Fokus UX yang Lebih Baik
  • Apa itu Google Workspace Studio? Tool Baru untuk Pembuat Konten?
  • Cara Menggunakan Xbox Full-Screen Experience di Windows
  • Korea Tahan Tersangka Terkait Penjualan Video Intim dari Kamera CCTV yang Diretas
  • Kebocoran Galaxy Buds 4 Mengungkap Desain dan Fitur Baru, Mirip Apple?
  • Sudah Update Windows KB5070311 dan Apa Saja Yang Diperbaiki?
  • Cara Menonaktifkan Fitur AI Actions (Tindakan AI) di Menu Windows Explorer
  • Microsoft Edge AI vs. OpenAI’s Atlas Browser: Perbandingan dan Perbedaan Utama
  • Cara Memasang Folder Sebagai Drive di Windows 11
  • Samsung Akan Luncurkan One UI 8.5 dengan Inspirasi ‘Liquid Glass’ yang Memukau
  • XBox Game Pass PC Tidak Bisa Address GPU ke Game
  • Your Pocket-Sized Doctors: 3 Health Apps Changing the Game on Android and iOS

©2025 emka.web.id | Design: Newspaperly WordPress Theme