Insert data from CSV file in PHP with PDO


// Database Connection
$hostname = "localhost";
$username = "root";
$password = "mf2312";

try {
    $db = new PDO("mysql:host=$servername;dbname=csvtest", $username, $password);
} catch (PDOException $e) {
    echo "Connection failed: " . $e->getMessage();

// Create  CSV to Array function

function csvToArray($filename = '', $delimiter = ',')
    if (!file_exists($filename) || !is_readable($filename)) {
        return false;

    $header = NULL;
    $result = array();
    if (($handle = fopen($filename, 'r')) !== FALSE) {
        while (($row = fgetcsv($handle, 1000, $delimiter)) !== FALSE) {
            if (!$header)
                $header = $row;

                $result[] = array_combine($header, $row);

    return $result;

// Insert data into database   

    $all_data = csvToArray('files/testcsv.csv');
    foreach ($all_data as $data) {

        $sql = $db->prepare("INSERT INTO students (name, roll, department) 
        VALUES (:name, :roll, :department)");
        $sql->bindParam(':name', $data['name']);
        $sql->bindParam(':roll', $data['roll']);
        $sql->bindParam(':department', $data['department']);


What I learned from my team in the beginning of my job.

I think that as a beginning  label  the most important it is to work  with a team.

When you work individually  you don’t know what you don’t know.  But when you join a team,  your senior  people and your team leader  find out your weak point and they are help  you in proper way  to improve your skill. You don’t know what the senior people know- no matter how good you think you are. It is good to exposure to both the best and the worst of what other people do. You can learn from both.

After learning programming and software development  a beginner  can write code and build project. But  in individual time period  he does not know how to write code in organized way  but if  he does work with a team he can learn from  senior people and team leader how to write aswame code.

We can learn lots of thing  from a team  such as team management system, group working, new technologies, new ideas etc.

What is HTTP? And what is the difference between GET and POST?

In this  article  we will be  discussing  about HTTP protocol. HTTP is the foundation of data communication for the world wide web. HTTP  stands for “Hyper Text Transfer Protocol”. It was implemented first by Tim Berners-Lee at CERN in 1990.The Hypertext Transfer Protocol (HTTP) is designed to enable communications between clients and servers.

HTTP works as a request-response protocol between a client and server.

A web browser using which a request is initiated is called as a client and a web server which respond’s to that request is called as a server.





  • Parameters remain in browser history because they are part of the URL.
  • The GET method is restricted to send upto 1024 characters only.
  • GET can’t be used to send binary data, like images or word documents, to the server.
  • GET method should not be used when sending passwords or other sensitive information.
  • The data sent by GET method can be accessed using QUERY_STRING environment variable.
  • Can be bookmarked.
  • The PHP provides $_GET associative array to access all the sent information using GET method.


  • Parameters are not saved in browser history.
  • The POST method does not have any restriction on data size to be sent.
  • The POST method can be used to send ASCII as well as binary data.
  • The data sent by POST method goes through HTTP header so security depends on HTTP protocol. By using Secure HTTP you can make sure that your information is secure.
  • Can not be bookmarked.
  • The PHP provides $_POST associative array to access all the sent information using POST method.

Simple pagination in PHP

This is a simple PHP pagination script. First create a database and create a table name users  then connect your database by hostname, username, password, dbname to run this script. you can change table name and add more column.


$conn = new mysqli('hostname', 'user', 'password', 'dbname');
$start = 0;
$limit = 10;

if (isset($_GET['id'])) {
    $id = $_GET['id'];
    $start = ($id - 1) * $limit;
} else {
    $id = 1;
$sql = "SELECT * FROM users LIMIT $start, $limit";
$query = $conn->query($sql);

        while ($result = mysqli_fetch_array($query)) { ?>
            <td><?= $result['name'] ?></td>
            <td><?= $result['department'] ?></td>
        <?php } ?>

    $rows = mysqli_num_rows(mysqli_query($dbconfig, "select * from user"));
    $total = ceil($rows / $limit);
    if ($id > 1) {
        echo "<a href='?id=" . ($id - 1) . "' class='button'>PREVIOUS</a>". "      ";
    if ($id != $total) {
        echo "<a href='?id=" . ($id + 1) . "' class='button'>NEXT</a>";
    <ul class='page'>
        for ($i = 1; $i <= $total; $i++) {
            if ($i == $id) {
                echo "<li class='current'>" . $i . "</li>";
            } else {
                echo "<li><a href='?id=" . $i . "'>" . $i . "</a></li>";