How to Create a Simple Search on MySQL Table using PHP, MySQLi and AJAX

In this tutorial, I'll show you how to create a simple search on mysql table using PHP, MySQLi and AJAX. This tutorial does not include a good design but will give you an idea on how to search for rows in mysql table.

Creating our Database

First, we're going to create our database. This contains the data that we are going to search. 1. Open phpMyAdmin. 2. Click databases, create a database and name it as "ajax_search". 3. After creating a database, click the SQL and paste the below code. See image below for detailed instruction.
  1. CREATE TABLE `user` (
  2.   `userid` INT(11) NOT NULL AUTO_INCREMENT,
  3.   `firstname` VARCHAR(30) NOT NULL,
  4.   `lastname` VARCHAR(30) NOT NULL,
  5. PRIMARY KEY(`userid`)
  6. ) ENGINE=InnoDB DEFAULT CHARSET=latin1;
search

Inserting Data into our Database

Next step is to insert example data into our database. This will serve as our sample data. 1. Click "ajax_search" database that we have created earlier. 2. Click SQL and paste the code below.
  1. INSERT INTO `user` (`firstname`, `lastname`) VALUES
  2. ('neovic', 'devierte'),
  3. ('lee', 'ann'),
  4. ('julyn', 'divinagracia'),
  5. ('jaira', 'jacinto');

Creating our Connection

Next step is to create a database connection and save it as "conn.php". This file will serve as our bridge between our form and our database. To create the file, open your HTML code editor and paste the code below after the tag.
  1. <?php
  2.  
  3. //MySQLi Procedural
  4. $conn = mysqli_connect("localhost","root","","ajax_search");
  5. if (!$conn) {
  6.         die("Connection failed: " . mysqli_connect_error());
  7. }
  8.  
  9. ?>

Creating our Form and our AJAX code

Next, we create our search form and our ajax code. This page will show if there are rows that matches our search. We name this as "index.php".
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <script>
  5. function showResult(str) {
  6.     if (str.length == 0) {
  7.         document.getElementById("search").innerHTML = "";
  8.         return;
  9.     } else {
  10.         var xmlhttp = new XMLHttpRequest();
  11.         xmlhttp.onreadystatechange = function() {
  12.             if (this.readyState == 4 && this.status == 200) {
  13.                 document.getElementById("search").innerHTML = this.responseText;
  14.                                
  15.             }
  16.         };
  17.         xmlhttp.open("GET", "getresult.php?q=" + str, true);
  18.         xmlhttp.send();
  19.     }
  20. }
  21. </script>
  22. </head>
  23. <body>
  24.  
  25. <form>
  26. First name: <input type="text" onkeyup="showResult(this.value)">
  27. <br><br>
  28. Results Found: <div id="search"></div>
  29. </form>
  30.  
  31. </body>
  32. </html>

Creating our Result Code

Lastly, we create our result code that will process user input and return the result back to our index.php. We name the code as "getresult.php".
  1. <?php
  2. // get the q parameter from URL
  3. $q = $_REQUEST["q"];
  4.  
  5. $hint = "";
  6.  
  7. include('conn.php');
  8.  
  9. $fname=array();
  10. $query=mysqli_query($conn,"select * from `user`");
  11. while($row=mysqli_fetch_array($query)){
  12.         $fname[]=$row['firstname'];
  13. }
  14.  
  15. // lookup all hints from array if $q is different from ""
  16. if ($q !== "") {
  17.     $q = strtolower($q);
  18.     $len=strlen($q);
  19.     foreach($fname as $name) {
  20.         if (stristr($q, substr($name, 0, $len))) {
  21.             if ($hint === "") {
  22.                 $hint = $name;
  23.             } else {
  24.                 $hint .="<br> $name";
  25.             }
  26.         }
  27.     }
  28. }
  29.  
  30. echo $hint === "" ? "no suggestion" : $hint;
  31. ?>

Comments

doesnt work this is bad very

Add new comment