Home » PHP28 November 2016

PHP MySQL: Simple CRUD (Add, Edit, Delete, View) using PDO

This article shows how to create a CRUD (Create, Read, Update, Delete) application in PHP & MySQL using PHP Data Objects (PDO). PDO is a PHP extension that provides an interface for accessing databases in PHP.

PDO is portable and powerful. There are many good features of PDO. The best one is that it’s cross-database compatible. You don’t need to change your query function if you switch database server for your project. PDO extension supports different databases like MS SQL, MySQL, Oracle, PostgreSQL, SQLite, etc.

The other benefit of PDO is error handling feature using exceptions. PDO functions can be written using try/catch block. The exceptions are logged in a log file and a user friendly error message is displayed on screen.

PDO also supports prepared statements and stored procedures. The major benefit of prepared statements is that you just need to prepare a query once and then it can be run multiple times with the same or different parameters. The other benefit is that prepared statements are quoted automatically by the driver. Hence, preventing SQL injection attack to the system/application.

In the past, I had written an article on creating a Simple CRUD System using PHP & MySQL. That article/tutorial uses MySQLi extension driver for accessing the database. In this article, we will be creating the same system but using PDO extension driver to access database.

Here is a step-by-step guide on creating a CRUD system using PHP & MySQL with PDO:

First of all, we will create a new MySQL database. Let us name the database as ‘test‘.

create database test;

Then, we will create a new table in database ‘test’. Let us name the table as ‘users‘.

use test;

id int(11) NOT NULL auto_increment,
name varchar(100) NOT NULL,
age int(3) NOT NULL,
email varchar(100) NOT NULL,

Now, we will create a config.php file which contains database connection code. This code connects to the MySQL database. This file is included in all PHP pages where database connection is necessary.


In below code, the database host name is localhost where username=root and password=root. The database test has been selected.

To add data into database, we need an html form.


Form action on add.html is add.php. It means that the submitted form data will go to add.php. In add.php, we do a simple validation of checking if the entered name, email & age are empty or not. If they are all filled then the data will be inserted into database table.


Data from database is fetched and displayed in index.php file. This is our homepage. This file also contains a link to add data. On every row of displayed data, there is also a link to edit and delete data. Below is a sample image of our homepage:



Each row of data can be edited separately. Row ID is passed in the URL of edit.php. ID uniquely identifies the data entry.

While adding data, we had two files: add.html and add.php. While editing data, I have kept the entire thing in a single edit.php file. Edit form in HTML and database update code in PHP are present in the same file.

In the code below, at first a single row entry of data is fetched based on the id. The fetched data is displayed in the edit form. When user edits the data and submits the form, then some simple validation is done for empty data. When everything is correct, then that particular entry of data is updated in database.


Each row of data can be deleted separately. Row ID is passed in the URL of delete.php. ID uniquely identifies the data entry. After deletion, the user is redirected to homepage (index.php).


Download Full Source Code: Simple PHP-MySQL CRUD (Add, Edit, Delete, View) using PDO

Hope this helps. Thanks.


Get New Post by Email

Find me on

FacebookTwitterGoogle+LinkedInRSS Feed
  • magento

  • ata ata

    thank you for the graet documantation.
    it works great.
    i have a quastion how i can make it responsive so that i can use it also mobile?
    can you help me?

  • alex

    thanx much for a very useful CRUD example it helped me a lot.Hope you’ll continue helping newbies like me…

  • Aj Shrestha

    lol i did the same after first data i couldnt add 2nd data

  • Adem Ozturk

    use bootstrap while coding

  • ahmed bdhief

    Thank you so much

  • saumya seth

    awsum…it worked…