View Single Post
  #3 (permalink)  
Old 2003-06-11, 05:16 PM
ld0121 ld0121 is offline
Junior Member
 
Join Date: Jun 2003
Posts: 2
ld0121
Default

Hi thanks for the reply, I put in the echos and found that it wasnt seeing the whole query so I have changed the query around a bit. The problem I have now is when I Search a word ie. "zone" which has only 1 entry in each table so 2 results, I get about 10 multiple results of exactly the same thing and results that dont contain "zone". The amount pf results returned equals the number of fields in the 2 tables, I dont understand why its doing this when the echo sugests that its just searching for zone....

select * from gzdata, gzdata1 where gzdata.name like '%zone%' OR gzdata1.name like '%zone%' ORDER by gzdata.name


Any other thoughts?

Cheers
Lee


Updated Code below:

<?php

// Get the search variable from URL

$var = @$_GET['q'] ;
$trimmed = trim($var); //trim whitespace from the stored variable

// rows to return
$limit=10;

// check for an empty string and display a message.
if ($trimmed == "")
{
echo "

Please enter a search...</p>";
exit;
}

// check for a search parameter
if (!isset($var))
{
echo "

We dont seem to have a search parameter!</p>";
exit;
}

//connect to your database
mysql_connect("localhost","XXX","XXXXX"); //(host, username, password)

//specify database
mysql_select_db("XXXXX") or die("Unable to select database"); //select which database we're using


// Build SQL Query
$query = "select * from gzdata, gzdata1 where gzdata.name like '%$trimmed%' OR gzdata1.name like '%$trimmed%' ORDER by gzdata.name";

{
echo "

SQL Query Output:</p>";
echo "$query";
print ("
" . mysql_error());
}



$numresults=mysql_query($query);
$numrows=mysql_num_rows($numresults);

// If we have no results, offer a google search as an alternative

if ($numrows == 0)
{
echo "<h4>Results</h4>";
echo "

Sorry, your search: "" . $trimmed . "" returned zero results</p>";

// google
echo "

<a href=\"http://www.google.com/search?q="
. $trimmed . "\" target=\"_blank\" title=\"Look up
" . $trimmed . " on Google\">Click here</a> to try the
search on google</p>";
}

// next determine if s has been passed to script, if not use 0
if (empty($s)) {
$s=0;
}

// get results
$query .= " limit $s,$limit";
$result = mysql_query($query) or die("Couldn't execute query");

// display what the person searched for
echo "

You searched for: "" . $var . ""</p>";

// begin to show results set
echo "Results
";
$count = 1 + $s ;

{
echo "

Results Output:</p>";
echo "$query";
echo " $result";
echo " $count";
print ("
" . mysql_error());
}

// now you can display the results returned
while ($row= mysql_fetch_array($result)) {
$url = $row["url"];
$name = $row["name"];
$info = $row["info"];

echo "$count.)Â*$name
$info
" ;
echo "<a href=\"" . $row["url"] . "\">$url</a>

";
$count++ ;
}

$currPage = (($s/$limit) + 1);

//break before paging
echo "
";

// next we need to do the links to other results
if ($s>=1) { // bypass PREV link if s is 0
$prevs=($s-$limit);
print "Â*<a href=\"$PHP_SELF?s=$prevs&q=$var\"><<
Prev 10</a>&nbspÂ*";
}

// calculate number of pages needing links
$pages=intval($numrows/$limit);

// $pages now contains int of pages needed unless there is a remainder from division

if ($numrows%$limit) {
// has remainder so add one page
$pages++;
}

// check to see if last page
if (!((($s+$limit)/$limit)==$pages) && $pages!=1) {

// not last page so give NEXT link
$news=$s+$limit;

echo "Â*<a href=\"$PHP_SELF?s=$news&q=$var\">Next 10 >></a>";
}

$a = $s + ($limit) ;
if ($a > $numrows) { $a = $numrows ; }
$b = $s + 1 ;
echo "

Showing results $b to $a of $numrows</p>";

?>
Reply With Quote