hoi,

Ik ben bezig met een zoekscript voor mijn php/mysql site. Dit script moet zoekresultaten geven van info die in een mysql database staat en die met behulp van php wordt uitgelezen op de website. Er moet gezocht worden in een specifieke tabel (in mijn script met de naam titel)

Na een zoektocht naar verschillende voorbeelden, ben ik uitgekomen bij onderstaand script.

Het werkt redelijk, alleen wil het me niet lukken om zoekresultaten als link weer te geven. Heeft iemand voor mij een (richting van de) oplossing?

Ben sowieso benieuwd wat jullie van onderstaand scirpt vinden. Het is een zeer eenvoudige manier van zoeken, maar voor mij is het dan ook de eerste keer dat ik met zoiets aan de gang ben. Andere scripts / tips zijn van harte welkom.

femke,

<?php

// Get the search variable from URL

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

// rows to return
$limit=5;

// check for an empty string and display a message.
if ($trimmed == "")
{
echo "<p>Geef een zoekterm...</p>";
exit;
}

// check for a search parameter
if (!isset($var))
{
echo "<p>We dont seem to have a search parameter!</p>";
exit;
}

//specify database ** EDIT REQUIRED HERE **
require("connecting database :-) ");

// Build SQL Query
$query = "SELECT * FROM nieuws WHERE titel like \"%$trimmed%\"
ORDER BY titel"; // EDIT HERE and specify your table and field names for the SQL query

$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 "<p>Sorry, your search: &quot;" . $trimmed . "&quot; returned zero results</p>";

// google
echo "<p><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 "<p>Je hebt gezocht op: &quot;" . $var . "&quot;</p>";

// begin to show results set
echo "Zoekresultaten <br><br>";
$count = 1 + $s ;

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

echo "$count.)&nbsp;$title<br><br>" ;
$count++ ;
}

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

//break before paging
echo "<br>";

// next we need to do the links to other results
if ($s>=1) { // bypass PREV link if s is 0
$prevs=($s-$limit);
print "&nbsp;<a href=\"$PHP_SELF?s=$prevs&q=$var\">&lt;&lt;
Prev 10</a>&nbsp&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 "&nbsp;<a href=\"$PHP_SELF?s=$news&q=$var\">Next 10 &gt;&gt;</a>";
}

$a = $s + ($limit) ;
if ($a > $numrows) { $a = $numrows ; }
$b = $s + 1 ;
echo "<p>Showing results $b to $a of $numrows</p>";

?>
Als je query er zo uit zou zien:
<?php
$query = "
SELECT id, titel
FROM nieuws WHERE titel like '%" . $trimmed . "%'
ORDER BY titel";
?>
Dan kun je je links zo echoën:
<?php
echo '<a href="?id=' . $row['id'] . '">'.$row['titel'].'</a>';
?>
Als iemand dan op zo'n link klikt, kun je via $_GET['id'] een query maken die het goede bericht ophaalt.
gaaf, het werkt. veel dank!

femke

Reageren