CRUD PHP Procedural Style


CRUD PHP Procedural Style
CRUD PHP Procedural Style
Sumber : blogs root93

ROOT93 - Artikel berikut ini merupakan rangkuman dari beberapa artikel sebelumnya mengenai hal – hal yang berkaitan dengan CRUD (Create, Read, Update, Delete) menggunakan perintah yang ditampung didalam function PHP, CRUD ini menggunakan gaya penulisan Procedural dimana teknik penulisannya berbeda dengan artikel CRUD di PHP sebelumnya, dimana disini saya menampung beberapa perintah atau eksekusi ke query didalam function serta menggunakan prepared statement.



Ada beberapa file CRUD yang akan dibuat disini diantarnya :

1. koneksi.php
2. function.php
3. input.php
4. tampil_data.php
5. detail.php
6. update.php
7. delete.php

Struktur database/tabel yang perlu Anda buat nanti :

1. id (int) 11
2. nim (varchar) 10
3. nama_mahasiswa (varchar) 30
4. tanggal_daftar (timestamp)

Buat sebuah koneksi ke database terlabih dahulu


<?php
define('DB_SERVER','localhost');
define('DB_USERNAME','root');
define('DB_PASSWORD', '');
define('DB_NAME','datamhs');
$koneksi = mysqli_connect(DB_SERVER, DB_USERNAME, DB_PASSWORD, DB_NAME);
if($koneksi == false){
 die ("Gagal melakukan koneksi ke database.".mysqli_connect_error());
}
?>


Selanjutnya kita bisa mendefinisikan beberapa function yang nantinya bisa dipanggil pada main kode atau kode utama yang akan memamnggil dan menjalankan perintah. Saya sudah membutkan beberapa function yang mungkin bisa Anda gunakan untuk keperluan CRUD, meskipun ini tidak terlalu sempurna, tapi saya pikir ini cocok untuk dijadikan bahan belajar. Untuk lebih lengkapnya Anda bisa melihat dan mempelajari baris kode dibawah ini :

<?php
//function simpan data
function simpan_mahasiswa($nim, $nama_mahasiswa){
    global $koneksi;
    $sql="INSERT INTO datamhs(nim, nama_mahasiswa) VALUES (?,?)";
    if($stmt=mysqli_prepare($koneksi, $sql)){
        mysqli_stmt_bind_param($stmt,"ss",$param_nim, $param_nama_mahasiswa);
        $param_nim = $nim;
        $param_nama_mahasiswa = $nama_mahasiswa;
      
 if(mysqli_stmt_execute($stmt)){
    return true;
 }else{
    return false;
 }

 }
 //Close statement
 mysqli_stmt_close($koneksi);
 //End function
 }
//function tampil data
function tampil_data(){
 global $koneksi
 $sql="SELECT id, nim, nama_mahasiswa, tanggal_daftar FROM datamhs";
 $result=mysqli_query($koneksi,$sql);
 return $result;
}
//function delete data

function delete_data($var_id){
 global $koneksi;
 $sql = "DELETE FROM datamhs where id =?";
 if($stmt=mysqli_prepare($koneksi, $sql)){
  mysqli_stmt_bind_param($stmt,"i", $param_id);
  $param_id = $var_id;
  
  if(mysqli_stmt_execute($stmt)){
   return true;
  }else{
   return false;
  }
 }
 
 mysqli_stmt_close($stmt);
}

function detail_data($var_id){
/*
ROOT93.co.id | COMPUTER | NETWORKING | WEB PROGRAMMING
*/
 global $koneksi;
 global $result;
 $sql="SELECT id, nama_mahasiswa, nim, tanggal_daftar FROM datamhs WHERE id=?";
 if($stmt=mysqli_prepare($koneksi, $sql)){
  mysqli_stmt_bind_param($stmt,"i",$param_id);
  $param_id = $var_id;
  if(mysqli_stmt_execute($stmt)){
   $result=mysqli_stmt_get_result($stmt);
   if(mysqli_num_rows($result)==1){
    return true; //jika ada data nilai true
   }else{
    return false; //jika data tidak ditemukan nilai false
   }
  }else{
   echo "Terjadi kesalahan";
  }
 }
 mysqli_stmt_close($stmt);
}

function update_data($var_id, $nim, $nama_mahasiswa){
 global $koneksi;
 $sql ="UPDATE datamhs SET nim=?, nama_mahasiswa=? WHERE id=?";
 if($stmt=mysqli_prepare($koneksi, $sql)){
  mysqli_stmt_bind_param($stmt,"ssi",$param_nim, $param_nama_mahasiswa, $param_id);
  //set parameter
  $param_id = $var_id;
  $param_nim = $nim;
  $param_nama_mahasiswa = $nama_mahasiswa;
  if(mysqli_stmt_execute($stmt)){
   return true;
  }else{
   return false;
  }
 }
}

?>



Membuat formulir untuk menginput data, Anda mungkin memerlukan filter tambahan selain hanya mengandalkan prepared statement, tapi mungkin itu akan saya jelaskan di video saja. Untuk kali ini saya rasa kode untuk menginput data seperti pada contoh dibawah ini sudah cukup.

<?php
include ('koneksi.php');
include ('function.php');
?>
<?php
//set variabel
$nim = $nama_mahasiswa = "";
$nim_err = $nama_mahasiswa_err = "";
if($_SERVER["REQUEST_METHOD"] == "POST"){
    if(empty(trim($_POST['nim']))){
        $nim_err = "Nim tidak boleh kosong";
    }else{
        $nim=$_POST['nim'];
        $nim=mysqli_real_escape_string($koneksi, $nim);
    }
    //
    if(empty(trim($_POST['nama_mahasiswa']))){
        $nama_mahasiswa_err = "Nama mahasiswa tidak boleh kosong";
    }else{
        $nama_mahasiswa = $_POST['nama_mahasiswa'];
        $nama_mahasiswa = mysqli_real_escape_string($koneksi, $nama_mahasiswa);
    }
//cek pakah input masih ada error
    if(empty($nim_err) && empty($nama_mahasiswa_err)){

    /* Panggil function */
        if(simpan_mahasiswa($nim, $nama_mahasiswa)){
            echo 'Berhasil menyimpan data';
            echo "<a href='tampil_data.php'>Tampil data</a>";
        }else{
            echo 'Gagal menyimpan data';
        }
      
}
  mysqli_close($koneksi);
  //close koneksi

    //end POST  
    }


?>

<html>
<head>
    <title>Input Mahasiswa root93</title>
</head>
<body>
<form method="post" action="<?php echo $_SERVER['PHP_SELF'] ?>">
<label>Nim :</label>
<input type="text" name="nim" size="15" />
<label>Nama Mahasiswa :</label>
<input type="text" name="nama_mahasiswa" size="15" />
<input type="Submit" name="submit" value="Submit">
</form>
<?php echo $nim_err; ?>
<?php echo $nama_mahasiswa_err; ?>
</body>
</html>


Selanjutnya menampilkan data – data, jika data ditemukan maka tampilkan data, namun jika tidak ada maka tampilkan pesan bahwa data tidak ditemukan. Untuk lebih jelasnya Anda bisa melihatnya pada halaman berikut :

<?php
include ('koneksi.php');
include ('function.php');
?>
<html>
<head>
 <title>Menampilkan data root93.co.id</title>
</head>
<body>

<?php
//memanggi function
$result = tampil_data();
  //mengeksekusi function didalam percabangan
  if($result){
  //jika data di tabel lebih besar dari 0 atau memiliki data maka eksekusi perulangan atau looping
  if(mysqli_num_rows($result)>0){
  echo "<table border='1' width='500'>";
  echo "<tr>";
  echo "<th>ID</th>";
  echo "<th>NIM</th>";
  echo "<th>NAMA MAHASISWA</th>";
  echo "<th>AKSI</th>";
  echo "</tr>";
  //loping data
  while($row=mysqli_fetch_array($result)){
  echo "<tr>";
  echo "<td>".$row['id']."</td>";
  echo "<td>".$row['nim']."</td>";
  echo "<td>".$row['nama_mahasiswa']."</td>";
  echo "<td>";
  echo "<a href='delete.php?id=".$row['id']." 'title = 'delete'>DELETE</a>";
  echo " | ";
  echo "<a href='detail.php?id=".$row['id']." 'title= detail'>DETAIL</a>";
  echo " | ";
  echo "<a href='update.php?id=".$row['id']." 'title= update'>UPDATE</a>";
  echo "</td>";

  echo "</tr>";
 }
  echo "</table>";
  echo "<a href='input.php'>Input data</a>";
  //free result
  mysqli_free_result($result);
 
 //namun jika tidak lebih besar dari pada > 0 atau tidak ditemukan data maka jalan perintah berikut
}else{
 echo "Data masih kosong";
}
//percabangan result ketika function tidak bisa mengeksekusi perintah
}else{
 echo "Terjadi kesalahan. Coba lagi nanti".mysqli_error($koneksi);
}
//close koneksi 
mysqli_close($koneksi);
?>

</body>
</html>


Menampilkan detail data menggunakan detail.php, jika link detail di klik, maka user akan diarahkan untuk melihat detail dari data yang bersangkutan. Anda bisa melihat contoh source codenya dibawah ini

<?php
/*
ROOT93.co.id | COMPUTER | NETWORKING | WEB PROGRAMMING
*/
include ('koneksi.php');
include ('function.php');
?>
<html>
<head>
 <title>DETAIL DATA ROOT93</title>
</head>
<body>

<?php
if(!empty($_GET['id'])){

 if(detail_data(trim($_GET['id']))){
  $row=mysqli_fetch_array($result);
 }else{
  die ("Data tidak ditemukan");
 }


}else{


  die("error");
 
}
mysqli_close($koneksi);


?>
<table border="1" width="500">
<tr>
 <th>ID</th>
 <th>NAMA MAHASISWA</th>
 <th>NIM</th>
 <th>TANGGAL DAFTAR</th>
</tr>
<tr>
 <td><?php echo $row['id'];?></td>
 <td><?php echo $row['nama_mahasiswa'];?></td>
 <td><?php echo $row['nim'];?></td>
 <td><?php echo $row['tanggal_daftar'];?></td>
</tr>
<a href="javascript:history.back()">Kembali</a>
</form>
</body>
</html>


Selanjutnya kita bisa membuat file update.php untuk melakukan proses update jika memang menginginkan perubahan pada data

<?php
/*
ROOT93.co.id | COMPUTER | NETWORKING | WEB PROGRAMMING
*/
include ('koneksi.php');
include ('function.php');
?>
<html>
<head>
 <title>UPDATE DATA ROOT93</title>
</head>
<body>

<?php
if(!empty($_GET['id'])){
 //memanggil fungsi detail data terlbeih dahulu
 if(detail_data(trim($_GET['id']))){
  $row=mysqli_fetch_array($result);
 }else{
  die ("Data tidak ditemukan");
 }


 }else{


   die("error");
  
}
?>

<?php
//jika ada request post maka jalankan percabangan
if($_SERVER["REQUEST_METHOD"]=="POST"){
 //simpan semua nilai variabel yang akan dikirim
 $var_id=trim($_POST['id']);
 $nim=trim($_POST['nim']);
 $nama_mahasiswa = trim($_POST['nama_mahasiswa']);
 //kemudian eksekusi di function update data
 if(update_data($var_id, $nim, $nama_mahasiswa)){
  echo "berhasil update";
 }else{
  die("Gagal update");
 }
}

?>
<table border="1" width="500">
<tr>

 <th>NAMA MAHASISWA</th>
 <th>NIM</th>

</tr>
<form action="<?php echo htmlspecialchars($_SERVER['REQUEST_URI']);?>" method="POST">
<tr>

 
 <td><input type="text" name="nama_mahasiswa" value="<?php echo $row['nama_mahasiswa'];?>"></td>
 <td><input type="text" name="nim" value="<?php echo $row['nim'];?>">
 <input type="hidden" name="id" value="<?php echo $row['id'];?>"></td>
</tr>
<input type="submit" name="kirim" value="Update" />
</form>

<a href="javascript:history.back()">Kembali</a>
</form>
</body>
</html>


Data yang tidak dibutuhkan bisa dihapus, Anda bisa menambahkan fungsi untuk melakukan pengahapusan data dengan memanggilnya melalui function yang tersedia

<?php
include ('koneksi.php');
include ('function.php');
?>
<html>
<head>
 <title>DELETE DATA ROOT93</title>
</head>
<body>

<?php
if(isset($_POST['id']) && !empty($_POST['id'])){
 //panggil function delete data
 if(delete_data(trim($_POST['id']))){
  echo "data berhasil dihapus";
  echo "<a href='tampil_data.php'>Tampil data</a>";
 }else{
  echo "Gagal mendelete data";
 }
//close koneksi

mysqli_close($koneksi);


}else{

 if(empty(trim($_GET["id"]))){
  header("location:error");
 }
}


?>
<form action="<?php echo htmlspecialchars($_SERVER['PHP_SELF']); ?>" method="POST">
<input type="hidden" name="id" value="<?php echo trim($_GET['id']); ?>" />
<p> Yakin ingin menghapus data ?</p>
<input type="submit" value="Ya">
<a href="javascript:history.back()">Kembali</a>
</form>
</body>
</html>


Tutorial Selanjutnya : CRUD PHP OOP Style (new)

CRUD PHP PROCEDURAL STYLE

Anda bisa mendownload dan mempelajari source codenya :
[ DOWNLOAD CODE ]

3 Responses to "CRUD PHP Procedural Style"

  1. HQQ, tahnks gan,, sangat bermanfaat, kebetulan ane lagi belajar nih,, mohon bimbingannya

    ReplyDelete
  2. Kalau buat saya, saya perhatiin postnya baik2 juga malah puyeng Kang T.T
    Belum ngertii, mesti lebih banyak lagi tentang PHP. Tapi jangan sering2 deh kalau di PHP

    ReplyDelete
  3. Sangat membantu sekali gan,, buat persiapan TA hahah

    ReplyDelete

Komentar yang Anda kirim akan terlebih dahulu di moderasi oleh Admin