Vyhľadávanie na stránkach patrí v dnešnej dobe medzi súčasť interaktívnych webových stránok. V dnešnej lekcii si vytvoríme skript, ktorý nám bude vyhľadávať naše uložené záznamy z databázy.
Pred pár rokmi bezvýznamná vec, dnes už nevyhnuteľnou súčasťou je vyhľadávanie na stránkach. My si ukáže len jednoduchý príklad, ako si vypísať naše uložené záznamy (ktoré sme si v minulej lekcii vložili) pomocou jednoduchého skriptu.
Len pre informáciu, všetky lekcie na seba nadväzujú, takže ten, čo nečítal predošlé lekcie, nebude zrejme všetkému chápať (doporučujem si prečítať).
Najprv sa samozrejme budeme musieť spojiť s našou databázou, to nám zabezpečí súbor databaza.inc.php.
databaza.inc.php
".SERVER.") na riadku číslo :".__LINE__."");
//Teraz vyberieme nasu databazu, v pripade chyby nechame si vypísat čislo riadku
//na ktorej sa chyba nacháza aj s popisom
$db=@mysql_select_db(DATABAZA,$connect) or die
("Chyba v pripojení k databázy (".DATABAZA.") na riadku číslo :".__LINE__."");
?>
V ďalšom skripte si vytvoríme formulár obsahujúci pole pre zadanie hľadaného textu a ďalšie pole typu select (s možnosťou výberu), kde si užívateľ sám vyberie, kde chce text hľadať.
Vyhľadávanie na stránke\n";
echo "
\n";
echo "\n";
echo "
\n";
?>
Nakoľko naša tabuľka mesta obsahuje aj stĺpec s celočíselnou hodnotou typu integer (int), bude relevantne lepšie, ak ich vypíšeme podľa normy STN (napr. 1 000 000, 5 500), to nám zabezpečí funkcia sformatovat.
Samotné vyhľadávanie nám v podstate zabezpečuje SQL dotaz.
Chceme od databázy SQL, aby nám vybrala všetky položky z tabuľky mesto, kde vybraná tabuľka bude obsahovať kdekoľvek zadaný výraz.
Samozrejme, SQL dotaz je ošetrený pred nežiadúcim HTML či PHP kódem a tiež pred vložením „žiadneho“ záznamu.
Takže celý script bude vypadať nasledovne.
Vyhľadávanie na stránke
Vyhľadávanie na stránke\n";
echo "
\n";
echo "\n";
echo "\n";
echo "Zadajte hladaný text : \n";
echo "Hľadať kde : \n";
echo " \n";
echo "Záznam : \n";
echo "\n";
echo "\n";
echo "";
echo "\n";
echo "\n";
echo " \n";
echo "
\n";
?>
Ľutujeme, ale nezadali ste žiaden text" ; exit;};
@require_once("databaza.inc.php");
echo "
\n";
//slq dotaz pre vyhladavanie na stranke
$sql="SELECT * FROM mesta WHERE ".addslashes(htmlspecialchars($_POST['kde']))." LIKE '%".addslashes(htmlspecialchars($_POST['search']))."%'";
$mysql_query=@mysql_query($sql,$connect);
$mysql_num_rows=@mysql_num_rows($mysql_query);
if ($mysql_num_rows==0) {
echo "Ľutujeme, ale Vašemu hľadanému výrazu ".addslashes(htmlspecialchars($_POST['search']))." neboli nájdené žiadne záznamy"; exit;
}
echo "
Nájdené záznamy [".$mysql_num_rows."] s textom ".addslashes(htmlspecialchars($_POST['search']))."
\n";
echo "
\n";
echo "\n";
echo "Štát \n";
echo "Hlavné Mesto \n";
echo "Počet Obyvateľov \n";
//vyberam data z databazy
while($rows=@mysql_fetch_array($mysql_query)) {
$stat=$rows['stat'];
$hlavne_mesto=$rows['hlavne_mesto'];
$pocet_obyvatelov=$rows['pocet_obyvatelov'];
//Nastavím design style Mouse over a out pre lepsie zobrazenie
$style='style="background-color:DADADA" onmouseover="this.style.backgroundColor = '.MOUSE_OVER.'" onmouseout="this.style.backgroundColor = '.MOUSE_OUT.'"';
echo "\n";
echo "".$stat." \n";
echo "".$hlavne_mesto." \n";
//vypisem uz sformatovany pocet obyvatelov
$hotove = sformatovat($pocet_obyvatelov);
echo "".$hotove." \n";
}
echo "
\n";
//ukoncim spojenie s mysql Serverom
@mysql_close($connect);
}
?>
Záver
Toto samozrejme bola len jednoduchá ukážka, ako si vytvoriť vyhľadávanie na našich stránkach. Ako ste mohli vidieť, podstatou vyhľadávanie je, aby bol text uložen v databáze. Čím viac uloženého textu je v našej databáze, tiem úspešnejšie bude aj naše vyhľadávanie. Aby som nezabudol, náš script sa dá vytvoriť aj za pomoci Javascriptu, ale vyzeralo by to relevantne zložitejšie.