Tutorial PHP : CRUD PDO OOP PHP

 
Dalam tutorial ini Saya akan memberikan contoh  CRUD PHP dengan gaya OOP (Object Oriented Programming)  PDO (PHP Data Object). Anda perlu belajar terlebih dahulu konsep pemrograman berbasis object php sebelum mempelajari tutorial ini, seperti tentang class, object, property dan method. 
 
Baca juga : 
 

Sturuktur Database/Tabel

Buatlah sebuah database terlebih dahulu, Anda bisa mengeksekusi atau mengimport data berikut :
Silahkan buat database dengan table seperti berikut :
 

    CREATE TABLE `tb_mahasiswa` (
  `id_mahasiswa` int(10) NOT NULL,
  `nim` varchar(10) NOT NULL,
  `nama_mahasiswa` varchar(50) NOT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

--
-- Dumping data for table `tb_mahasiswa`
--

INSERT INTO `tb_mahasiswa` (`id_mahasiswa`, `nim`, `nama_mahasiswa`) VALUES
(12, '10256874', 'Ahmad Zaelani'),
(13, '10256875', 'Andini Maheswari'),
(14, '10256876', 'Rudi Alamsyah'),
(15, '10256877', 'Sinta Oktasari'),
(16, '10256878', 'Hadi Nurcahya'),
(17, '10256879', 'Sari Purnama');

--
-- Indexes for dumped tables
--

--
-- Indexes for table `tb_mahasiswa`
--
ALTER TABLE `tb_mahasiswa`
  ADD PRIMARY KEY (`id_mahasiswa`);
  
  
 

Koneksi ke Database MySQL Dengan OOP PDO

Langkah pertama Anda perlu membuat sebuah koneksi ke database mysql, ada berbagai cara yang bisa Anda gunakan, karena ini menggunakan gaya OOP PHP, maka saya memberikan contoh sederhana bagaimana melakukan koneksi ke database MySQL dengan gaya OOP PDO, anda bisa memberikan nama pada file ini misal dengan nama database.php
 

<?php


	
class database
{
	private $host="localhost";
	private $user="root";
	private $pass="";
	private $db="codexam";
	protected $koneksi;
	public function __construct(){

		try
		{
				$this->koneksi = new PDO("mysql:host=$this->host; dbname=$this->db",$this->user, $this->pass);
				$this->koneksi->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
		}
		catch(PDOException $e)
		{
				echo $e->getMessage();
		}
		return $this->koneksi;
	}
		
}

?>


 

Melakukan Operasi CRUD PHP PDO

Disini untuk query – query yang digunakan untuk melakukan proses CRUD akan dibuat secara terpisah, supaya lebih mudah dimengerti, salin/tulis file ini dengan nama sql.php
 

<?php
class crud extends database
{
	
	
	public function showData()
	{
		$sql ="SELECT * FROM tb_mahasiswa";
		$stmt=$this->koneksi->prepare($sql);
		$stmt->execute();
		return $stmt;
	}
	public function insertData($nim, $nama)
	{
		try
		{
			$sql="INSERT INTO tb_mahasiswa(nim, nama_mahasiswa) VALUES (:nim, :nama_mahasiswa)";
			$stmt=$this->koneksi->prepare($sql);
				$stmt->bindParam(":nim",$nim);
				$stmt->bindParam(":nama_mahasiswa", $nama);
				$stmt->execute();
				return true;
		}
		catch(PDOException $e)
		{
				echo $e->getMessage();
				return false;
				
			
		}
	}
	public function detailData($data)
	{
		# GET DATA
		try
		{
			$sql ="SELECT id_mahasiswa, nim, nama_mahasiswa FROM tb_mahasiswa WHERE id_mahasiswa=:id_mahasiswa";
			$stmt=$this->koneksi->prepare($sql);
			$stmt->bindParam(":id_mahasiswa",$data);
			$stmt->execute();
			$stmt->bindColumn(1, $this->id_mahasiswa);
			$stmt->bindColumn(2, $this->nim);
			$stmt->bindColumn(3, $this->nama_mahasiswa);
			$stmt->fetch(PDO::FETCH_ASSOC);
			if($stmt->rowCount()==1):
				return true;
			else:
				return false;
			endif;

			
		}
		catch(PDOException $e)
		{
			echo $e->getMessage();
			
		}
	}
	public function detailData_duatest($data)
	{
		# Sample GET DATA by ID
		try
		{
			$sql ="SELECT id_mahasiswa, nim, nama_mahasiswa FROM tb_mahasiswa WHERE id_mahasiswa=:id_mahasiswa";
			$stmt=$this->koneksi->prepare($sql);
			$stmt->execute(array(":id_mahasiswa"=>$data));
			$this->row=$stmt->fetch(PDO::FETCH_ASSOC);
			return $this->row;
		}
		catch(PDOException $e)
		{
			echo $e->getMessage();
		}
	}
	public function updateData($nim, $nama, $data)
	{
		try
		{
			$sql="UPDATE tb_mahasiswa SET nim=:nim, nama_mahasiswa=:nama_mahasiswa WHERE id_mahasiswa=:id_mahasiswa";
			$stmt=$this->koneksi->prepare($sql);
			$stmt->bindParam(":nim",$nim);
			$stmt->bindParam(":nama_mahasiswa",$nama);
			$stmt->bindParam(":id_mahasiswa",$data);
			$stmt->execute();
			return true;
		}
		catch(PDOException $e)
		{
			echo $e->getMessage();
			return false;
		}
	}
	public function delete ($data)
	{
		try{
			$sql="DELETE FROM tb_mahasiswa WHERE id_mahasiswa=:id_mahasiswa";
			$stmt=$this->koneksi->prepare($sql);
			$stmt->execute(array("id_mahasiswa"=>$data));
			return true;
		}
		catch(PDOException $e)
		{
			echo $e->getMessage();
			return false;
		}
	}
}
?>



Menampilkan Data dan Membuat Antar Muka untuk Input Data Dengan PHP PDO

Buat sebuah file dengan nama index.php, contoh file/script bisa Anda tulis seperti berikut :



<?php

require_once ('database.php');
require_once ('sql.php');

$obj = new crud;

if($_SERVER['REQUEST_METHOD']=='POST'):
	$nim  = $_POST['nim'];
	$nama = $_POST['nama_mahasiswa'];
	if($obj->insertData($nim, $nama)):
		echo '<div class="alert alert-success">Data berhasil disimpan</div>';
	else:

		echo '<div class="alert alert-danger">Data berhasil disimpan</div>';
	endif;
endif;
?>
<!DOCTYPE html>
<html>
<head>
	<title>Tutorial PHP : CRUD PDO PHP</title>

	<link href="../assets/fontawesome-free/css/all.min.css" rel="stylesheet" type="text/css">
	<link href="../assets/bootstrap/css/bootstrap.min.css" rel="stylesheet" type="text/css">

</head>
<body>
	<div class="container">
		<div class="card shadow mb-4 mt-4">
	            <div class="card-header py-3">
	                <h6 class="m-0 font-weight-bold text-primary">Tutotrial PHP : CRUD PDO OOP PHP - ROOT93.CO.ID</h6>
	            </div>
	        <form action="<?php echo $_SERVER['PHP_SELF']; ?>" method="post">
		        <div class="card-body">
					<div class="row">
						
						<div class="col-md-4">
							<div class="form-group">
								<label>NIM :</label>
								<input type="text" class="form-control" name="nim"/>
							</div>
						</div>
						<div class="col-md-4">
							<div class="form-group">
								<label>NAMA MAHASISWA :</label>
								<input type="text" class="form-control" name="nama_mahasiswa"/>
							</div>
						</div>
						<div class="col-md-4">
							
								<button type="submit" class="mt-4 btn btn-md btn-primary"> Simpan</button>
						
						</div>
					</div>
				</div>
			</form>
			<div class="row m-auto">
				<table class="table table-bordered">
					<tr>
						<th>NO</th>
						<th>NIM</th>
						<th>NAMA MAHASISWA</th>
						<th>AKSI</th>
					</tr>
					<?php 
					$no=1;
						$data=$obj->showData();
						if($data->rowCount()>0){
						while($row=$data->fetch(PDO::FETCH_ASSOC)){
					?>
					<tr>
						<td><?php echo $no; ?></td>
						<td><?php echo $row['nim']; ?></td>
						<td><?php echo $row['nama_mahasiswa']; ?></td>
						<td>
							<?php echo "<a class='btn btn-sm btn-primary' href='edit.php?id_mahasiswa=".$row['id_mahasiswa']."'>edit</a>"; ?>
							<?php echo "<a class='btn btn-sm btn-primary' href='delete.php?id_mahasiswa=".$row['id_mahasiswa']."'>delete</a>"; ?>
						</td>
					</tr>
					<?php $no+=1; } $data->closeCursor();

									}else{
										echo '
											<tr>
												<td> Not found</td>
											</tr>
										';
									}
									?>
				</table>
			</div>
		</div>
	</div>

<script src="../assets/jquery/jquery.min.js"></script>
<script src="../assets/bootstrap/js/bootstrap.bundle.min.js"></script>
</body>
</html>



Halaman Edit/Update

Selanjutnya disini kita akan membuat halaman / antarmuka untuk melakukan edit/update data, Anda bisa membuat file baru dengan nama misal edit.php dan menulis isi filenya dengan kode seperti berikut ini :
 


<?php

require_once ('database.php');
require_once ('sql.php');
$obj = new crud;

if(!$obj->detailData($_GET['id_mahasiswa'])) die("Error : id mahasiswa tidak ada");
if($_SERVER['REQUEST_METHOD']=='POST'):
	$nim  = $_POST['nim'];
	$nama = $_POST['nama_mahasiswa'];
	if($obj->updateData($nim, $nama, $obj->id_mahasiswa)):
		echo '<div class="alert alert-success">Data berhasil disimpan</div>';
	else:

		echo '<div class="alert alert-danger">Data berhasil disimpan</div>';
	endif;
endif;
?>
<!DOCTYPE html>
<html>
<head>
	<title>Tutorial PHP : CRUD OOP PHP</title>

	<link href="../assets/fontawesome-free/css/all.min.css" rel="stylesheet" type="text/css">
	<link href="../assets/bootstrap/css/bootstrap.min.css" rel="stylesheet" type="text/css">

</head>
<body>
	<div class="container">
		<div class="card shadow mb-4 mt-4">
	            <div class="card-header py-3">
	                <h6 class="m-0 font-weight-bold text-primary">Tutotrial PHP : CRUD PDO OOP PHP - ROOT93.CO.ID</h6>
	            </div>
	        <form action="<?php echo $_SERVER['REQUEST_URI']; ?>" method="post">
		        <div class="card-body">
					<div class="row">
						
						<div class="col-md-4">
							<div class="form-group">
								<label>NIM :</label>
								<input type="text" class="form-control" name="nim" value="<?php echo $obj->nim; ?>"/>
							</div>
						</div>
						<div class="col-md-4">
							<div class="form-group">
								<label>NAMA MAHASISWA :</label>
								<input type="text" class="form-control" name="nama_mahasiswa" value="<?php echo $obj->nama_mahasiswa; ?>"/>
							</div>
						</div>
						<div class="col-md-4">
							
								<button type="submit" class="mt-4 btn btn-md btn-primary"> Simpan</button>
								<a href="index.php" class="mt-4 btn btn-md btn-primary">Kembali</a>
						
						</div>
					</div>
				</div>
			</form>
	
		</div>
	</div>

<script src="../assets/jquery/jquery.min.js"></script>
<script src="../assets/bootstrap/js/bootstrap.bundle.min.js"></script>
</body>
</html>



Halaman Delete

Terakhir Anda bisa membuat halaman untuk proses delete data, Anda bisa menyalin contoh kode dibawah kemudian menyimpannya dengan nama file delete.php



<?php

require_once ('database.php');
require_once ('sql.php');

$obj = new crud;

if(!$obj->detailData($_GET['id_mahasiswa'])) die("Error : id mahasiswa tidak ada");
if($_SERVER['REQUEST_METHOD']=='POST'):

	if($obj->delete($obj->id_mahasiswa)):
		echo '<div class="alert alert-success">Data berhasil dihapus</div>';
	else:

		echo '<div class="alert alert-danger">Data berhasil disimpan</div>';
	endif;
endif;
?>
<!DOCTYPE html>
<html>
<head>
	<title>Tutorial PHP : CRUD OOP PHP</title>

	<link href="../assets/fontawesome-free/css/all.min.css" rel="stylesheet" type="text/css">
	<link href="../assets/bootstrap/css/bootstrap.min.css" rel="stylesheet" type="text/css">

</head>
<body>
	<div class="container">
		<div class="card shadow mb-4 mt-4">
	            <div class="card-header py-3">
	                <h6 class="m-0 font-weight-bold text-primary">Tutotrial PHP : CRUD PDO OOP PHP - ROOT93.CO.ID</h6>
	            </div>
	        <form action="<?php echo $_SERVER['REQUEST_URI']; ?>" method="post">
		        <div class="card-body">
					<button type="submit" class="mt-4 btn btn-md btn-primary">Delete</button>
					<a href="index.php" class="mt-4 btn btn-md btn-primary">Kembali</a>
				</div>
			</form>
	
		</div>
	</div>

<script src="../assets/jquery/jquery.min.js"></script>
<script src="../assets/bootstrap/js/bootstrap.bundle.min.js"></script>
</body>
</html>



Tutorial PHP : CRUD PDO OOP PHP

[ DOWNLOAD SOURCE CODE ]


Dan selenjutnya Saya akan memberikan contoh, teknik atau trik menyederhanakan kode diatas atau meringkas kode query supaya lebih mudah untuk digunakan. [ Baca : Tutorial PHP : CRUD PDO OOP PHP Part 2 - Meringkas Kode ]


0 Response to "Tutorial PHP : CRUD PDO OOP PHP"

Post a Comment

Komentar yang Anda kirim akan terlebih dahulu di moderasi oleh Admin