vraag over bijna voltooid zoekscript

Overzicht Reageren

Sponsored by: Vacatures door Monsterboard

Femke

femke

17/08/2006 22:35:00
Quote Anchor link
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,

Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
<?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>";
  
?>
 
PHP hulp

PHP hulp

16/11/2024 15:48:07
 
Femke

femke

17/08/2006 22:40:00
Quote Anchor link
zit ik in de juiste richting met:

<a href=\"$row[titel]\">".$row['titel;']."</a>

toe te voegen bij regel 50?
Gewijzigd op 01/01/1970 01:00:00 door femke
 
Michael -

Michael -

17/08/2006 22:40:00
Quote Anchor link
Volgens mij wel een oud script:

Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
<?php
echo "&nbsp;<a href=\"$PHP_SELF?s=$news&q=$var\">Next 10 &gt;&gt;</a>";
?>

zou beter zijn:
Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
<?php
echo '&nbsp;<a href="'.$_SERVER['PHP_SELF'].'?s='.$news.'&q='.$var.'">Next 10 &gt;&gt;</a>';
?>
Gewijzigd op 01/01/1970 01:00:00 door Michael -
 
Klaasjan Boven

Klaasjan Boven

17/08/2006 22:42:00
Quote Anchor link
Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
<?php
$var
= @$_GET['q'] ;
  $trimmed = trim($var);
?>


Dat kan volgens mij beter met:
Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
6
7
8
9
10
11
<?php
if(isset($_GET['q'])){
$var=$_GET['q'];
}

else{
$var niet geset blabla;
}

?>



}
Gewijzigd op 01/01/1970 01:00:00 door Klaasjan Boven
 
Michael -

Michael -

17/08/2006 22:45:00
Quote Anchor link
Ontopic:

Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
6
7
8
9
<?php
// now you can display the results returned
  while ($row= mysql_fetch_array($result)) {
  $title = $row["titel"];

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

?>

Handig dat commentaar ;) Hier moet je dus je link plaatsen.
Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
<?php
echo "$count.)&nbsp;$title<br><br>" ;
?>

veranderen in
Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
<?php
echo $count.'&nbsp;<a href="eenpagina.php">'.$title.'</a><br><br>';
?>


Waar staat .) voor? Ik zie niet waar het voor dient.
 
Femke

femke

17/08/2006 22:53:00
Quote Anchor link
hartelijk dank voor de snelle snelle reacties. Ik ga er mee aan de slag.

<quote>
Volgens mij wel een oud script:
</quote>

inderdaad, kan helaas geen nieuwere vinden.
 
Femke

femke

17/08/2006 23:02:00
Quote Anchor link
@Turmijn,

je vraag: Waar staat count.) voor?

het antwoord: de count.) zorgt dat er voor ieder zoekresultaat een nummer komt te staan gevolgd door een .) dus 1.) zoekresiltaat 2.) zoekresultaat 3.)......

duzzzzz
 
Klaasjan Boven

Klaasjan Boven

17/08/2006 23:02:00
Quote Anchor link
Quote:
<quote>
Volgens mij wel een oud script:
</quote>


je moet deze [] gebruiken
 
Femke

femke

17/08/2006 23:07:00
Quote Anchor link
Quote:
je moet deze [] gebruiken


OK
 
Michael -

Michael -

17/08/2006 23:14:00
Quote Anchor link
@Femke: Haha ja oke best logisch :)
Als je het script wilt gebruiken zal ik wel de dingen die bovenaan al genoemd zijn, veranderen en alle vars buiten qoutes houden.
 
Femke

femke

18/08/2006 10:12:00
Quote Anchor link
de aangedragen aanpassingen zijn doorgevoerd.

wat ik alleen nog niet voor elkaar heb is dat het zoekresultaat automatisch wordt gelinkt (kan via het ID) naar het bijbehorende bericht.

Iemand een idee hoe ik dit voor elkaar kan krijgen? Ik heb nu zoiets als:

Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
<?php
echo "$count.'&nbsp;<a href=\"index.php?page=nieuws&id\">'.$title.'</a><br><br>";
?>
Gewijzigd op 01/01/1970 01:00:00 door femke
 
Jan Koehoorn

Jan Koehoorn

18/08/2006 10:23:00
Quote Anchor link
Als je query er zo uit zou zien:
Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
4
5
6
<?php
$query
= "
    SELECT id, titel
    FROM nieuws WHERE titel like '%"
. $trimmed . "%'
    ORDER BY titel"
;
?>

Dan kun je je links zo echoën:
Code (php)
PHP script in nieuw venster Selecteer het PHP script
1
2
3
<?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.
 
Femke

femke

18/08/2006 11:09:00
Quote Anchor link
gaaf, het werkt. veel dank!

femke
 



Overzicht Reageren

 
 

Om de gebruiksvriendelijkheid van onze website en diensten te optimaliseren maken wij gebruik van cookies. Deze cookies gebruiken wij voor functionaliteiten, analytische gegevens en marketing doeleinden. U vindt meer informatie in onze privacy statement.