PHP MySql OOP CRUD Example
May 08, 2021 . Admin
Hello Friends,
In This Blog, I would like to share perform crud operation using oop in PHP application. We will perform crud opeartion like create read upadte delete operation in PHP oop.
CRUD is basic step of any core language framework. CRUD stands for Create Read Update and Delete. So In this blog we will learn you insert upadte and delete in PHP oop with mysql database.
You just need to follow few step and you will get basic crud using php oop with mysql database.
Here I will give you full example for crud operation example in OOP PHP. So, let's follow few step to create example of PHP oop crud application tutorial.
Following file Structure
- index.php
- customers.php
- add.php
- edit.php
CREATE TABLE `customers` ( `id` int(11) NOT NULL AUTO_INCREMENT PRIMARY KEY, `name` varchar(100) NOT NULL, `email` varchar(100) NOT NULL, `salary` varchar(100) NOT NULL ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;Create Employee Class with CRUD method
Now, We will create class for MySQL database connections and CRUD operations, like Select, insert, update and delete with MySQL database. We'll have a displayData() method for selecting customer records, an insertData() method for inserting customer records, an updateRecord() method for updating customer data, and a deleteRecord() method for deleting customer records. and displayRecordById() method for fetch single record. Here is a complete Employee class with all its methods. All you need to do is change the MySQL database connection details while it is running on your server.
customers.php<?php class Employee { private $servername = "localhost"; private $username = "root"; private $password = "root"; private $database = "php_curd"; public $con; // Database Connection public function __construct() { $this->con = new mysqli($this->servername, $this->username,$this->password,$this->database); if(mysqli_connect_error()) { trigger_error("Failed to connect to MySQL: " . mysqli_connect_error()); }else{ return $this->con; } } // Insert customer data into customer table public function insertData($post) { $name = $this->con->real_escape_string($_POST['name']); $email = $this->con->real_escape_string($_POST['email']); $salary = $this->con->real_escape_string($_POST['salary']); $query="INSERT INTO customers(name,email,salary) VALUES('$name','$email','$salary')"; $sql = $this->con->query($query); if ($sql==true) { header("Location:index.php?msg1=insert"); }else{ echo "Registration failed try again!"; } } // Fetch customer records for show listing public function displayData() { $query = "SELECT * FROM customers"; $result = $this->con->query($query); if ($result->num_rows > 0) { $data = array(); while ($row = $result->fetch_assoc()) { $data[] = $row; } return $data; }else{ echo "No found records"; } } // Fetch single data for edit from customer table public function displyaRecordById($id) { $query = "SELECT * FROM customers WHERE id = '$id'"; $result = $this->con->query($query); if ($result->num_rows > 0) { $row = $result->fetch_assoc(); return $row; }else{ echo "Record not found"; } } // Update customer data into customer table public function updateRecord($postData) { $name = $this->con->real_escape_string($_POST['uname']); $email = $this->con->real_escape_string($_POST['uemail']); $salary = $this->con->real_escape_string($_POST['usalary']); $id = $this->con->real_escape_string($_POST['id']); if (!empty($id) && !empty($postData)) { $query = "UPDATE customers SET name = '$name', email = '$email', salary = '$salary' WHERE id = '$id'"; $sql = $this->con->query($query); if ($sql==true) { header("Location:index.php?msg2=update"); }else{ echo "Registration updated failed try again!"; } } } // Delete customer data from customer table public function deleteRecord($id) { $query = "DELETE FROM customers WHERE id = '$id'"; $sql = $this->con->query($query); if ($sql==true) { header("Location:index.php?msg3=delete"); }else{ echo "Record does not delete try again"; } } } ?>Insert Record
Now we will insert customer record using insertData() method from customers Class. For this, we will design a customer HTML Form in add.php file.
add.php<?php // Include database file include 'customers.php'; $customerObj = new Employee(); // Insert Record in customer table if(isset($_POST['submit'])) { $customerObj->insertData($_POST); } ?> <!DOCTYPE html> <html lang="en"> <head> <title>PHP MySql OOP CRUD Example Tutorial</title> <meta charset="utf-8"> <meta name="viewport" content="width=device-width, initial-scale=1"> <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.5.2/css/bootstrap.min.css"> <link rel="stylesheet" href="https://pro.fontawesome.com/releases/v5.10.0/css/all.css"/> </head> <body> <div class="card text-center" style="padding:15px;"> <h4>PHP MySql OOP CRUD Example Tutorial</h4> </div><br> <div class="container"> <div class="row"> <div class="col-md-5 mx-auto"> <div class="card"> <div class="card-header bg-dark text-white"> <h4>Insert Data</h4> </div> <div class="card-body bg-light"> <form action="add.php" method="POST"> <div class="form-group"> <label for="name">Name:</label> <input type="text" class="form-control" name="name" placeholder="Enter name" required=""> </div> <div class="form-group"> <label for="email">Email</label> <input type="email" class="form-control" name="email" placeholder="Enter email" required=""> </div> <div class="form-group"> <label for="salary">Salary:</label> <input type="text" class="form-control" name="salary" placeholder="Enter Salary" required=""> </div> <input type="submit" name="submit" class="btn btn-primary" style="float:right;" value="Submit"> </form> </div> </div> </div> </div> </div> <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script> <script src="https://maxcdn.bootstrapcdn.com/bootstrap/4.5.2/js/bootstrap.min.js"></script> </body> </html>Display Data
Now we will display customer records using displyaData() method from customers Class
index.php<?php // Include database file include 'customers.php'; $customerObj = new Employee(); // Delete record from table if(isset($_GET['deleteId']) && !empty($_GET['deleteId'])) { $deleteId = $_GET['deleteId']; $customerObj->deleteRecord($deleteId); } ?> <!DOCTYPE html> <html lang="en"> <head> <title>PHP MySql OOP CRUD Example Tutorial</title> <meta charset="utf-8"> <meta name="viewport" content="width=device-width, initial-scale=1"> <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.5.2/css/bootstrap.min.css"> <link rel="stylesheet" href="https://pro.fontawesome.com/releases/v5.10.0/css/all.css"/> </head> <body> <div class="card text-center" style="padding:15px;"> <h4>PHP MySql OOP CRUD Example Tutorial</h4> </div><br><br> <div class="container"> <?php if (isset($_GET['msg1']) == "insert") { echo "<div class='alert alert-success alert-dismissible'> <button type='button' class='close' data-dismiss='alert'>×</button> Your Registration added successfully </div>"; } if (isset($_GET['msg2']) == "update") { echo "<div class='alert alert-success alert-dismissible'> <button type='button' class='close' data-dismiss='alert'>×</button> Your Registration updated successfully </div>"; } if (isset($_GET['msg3']) == "delete") { echo "<div class='alert alert-success alert-dismissible'> <button type='button' class='close' data-dismiss='alert'>×</button> Record deleted successfully </div>"; } ?> <h2>View Records <a href="add.php" style="float:right;"><button class="btn btn-success"><i class="fas fa-plus"></i></button></a> </h2> <table class="table table-hover"> <thead> <tr> <th>Id</th> <th>Name</th> <th>Email</th> <th>Salary</th> <th>Action</th> </tr> </thead> <tbody> <?php $customers = $customerObj->displayData(); foreach ($customers as $customer) { ?> <tr> <td><?php echo $customer['id'] ?></td> <td><?php echo $customer['name'] ?></td> <td><?php echo $customer['email'] ?></td> <td><?php echo $customer['salary'] ?></td> <td> <button class="btn btn-primary mr-2"><a href="edit.php?editId=<?php echo $customer['id'] ?>"> <i class="fa fa-pencil text-white" aria-hidden="true"></i></a></button> <button class="btn btn-danger"><a href="index.php?deleteId=<?php echo $customer['id'] ?>" onclick="confirm('Are you sure want to delete this record')"> <i class="fa fa-trash text-white" aria-hidden="true"></i> </a></button> </td> </tr> <?php } ?> </tbody> </table> </div> <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script> <script src="https://maxcdn.bootstrapcdn.com/bootstrap/4.5.2/js/bootstrap.min.js"></script> </body> </html>Update Record
Now we will handle functionality to update and edit customer in file edit.php. first we will create customer edit HTML Form.
edit.php<?php // Include database file include 'customers.php'; $customerObj = new Employee(); // Edit customer record if(isset($_GET['editId']) && !empty($_GET['editId'])) { $editId = $_GET['editId']; $customer = $customerObj->displyaRecordById($editId); } // Update Record in customer table if(isset($_POST['update'])) { $customerObj->updateRecord($_POST); } ?> <!DOCTYPE html> <html lang="en"> <head> <title>PHP MySql OOP CRUD Example Tutorial</title> <meta charset="utf-8"> <meta name="viewport" content="width=device-width, initial-scale=1"> <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.5.2/css/bootstrap.min.css"> <link rel="stylesheet" href="https://pro.fontawesome.com/releases/v5.10.0/css/all.css"/> </head> <body> <div class="card text-center" style="padding:15px;"> <h4>PHP MySql OOP CRUD Example Tutorial</h4> </div><br> <div class="container"> <div class="row"> <div class="col-md-5 mx-auto"> <div class="card"> <div class="card-header bg-primary"> <h4 class="text-white">Update Records</h4> </div> <div class="card-body bg-light"> <form action="edit.php" method="POST"> <div class="form-group"> <label for="name">Name:</label> <input type="text" class="form-control" name="uname" value="<?php echo $customer['name']; ?>" required=""> </div> <div class="form-group"> <label for="email">Email</label> <input type="email" class="form-control" name="uemail" value="<?php echo $customer['email']; ?>" required=""> </div> <div class="form-group"> <label for="salary">Salary:</label> <input type="text" class="form-control" name="usalary" value="<?php echo $customer['salary']; ?>" required=""> </div> <div class="form-group"> <input type="hidden" name="id" value="<?php echo $customer['id']; ?>"> <input type="submit" name="update" class="btn btn-primary" style="float:right;" value="Update"> </div> </form> </div> </div> </div> </div> </div> <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script> <script src="https://maxcdn.bootstrapcdn.com/bootstrap/4.5.2/js/bootstrap.min.js"></script> </body> </html>
You will see layout as like bellow:
List PageAdd Page
Edit Page
I Hope It will help you..