I have made the following search script but can only search one table column when querying the database:
$query = "select * from explore where site_name like '%".$searchterm."%'";
I would like to know how I can search the entire table(explore). Also, I would need to fix this line of code:
echo "$num_found. ".($row['site_name'])." <br />";
One last thing that is bugging me is when I push the submit button on a different page I always displays the message “Please enter a search term.” even when I enter in something?
Thanks for any help, here is the entire script if needed:
<?php
// Set variables from form.
$searchterm = $_POST['searchterm'];
trim ($searchterm);
// Check if search term was entered.
if (!$serachterm)
{
echo "Please enter a search term.";
}
// Add slashes to search term.
if (!get_magic_quotes_gpc())
{
$searchterm = addcslashes($searchterm);
}
// Connects to database.
@ $dbconn = new mysqli('localhost', 'root', 'root', 'ajax_demo');
if (mysqli_connect_errno())
{
echo "Could not connect to database. Please try again later.";
exit;
}
// Query the database.
$query = "select * from explore where site_name like '%".$searchterm."%'";
$result = $dbconn->query($query);
// Number of rows found.
$num_results = $result->num_rows;
echo "Found: ".$num_results."</p>";
// Loops through results.
for ($i=0; $i <$num_results; $i++)
{
$num_found = $i + 1;
$row = $result->fetch_assoc();
echo "$num_found. ".($row['site_name'])." <br />";
}
// Escape database.
$result->free();
$dbconn->close();
?>
Contrary to other answers, I think you want to use “OR” in your query, not “AND”:
Replace
other_columnwith the name of a second column. You can keep repeating the part I added for each of your columns.Note: this is assuming that your variable
$searchtermhas already been escaped for the database, for example with$mysqli->real_escape_string($searchterm);. Always ensure that is the case, or better yet use parameterised queries.Similarly when outputting your variables like
$row['site_name']always make sure you escape them for HTML, for example usinghtmlspecialchars($row['site_name']).Make sure that both forms use the same method (post in your example). The
<form>tag should have the attributemethod="post".Also, what is wrong with the line of code you mentioned? Is there an error? It should work as far as I can tell.