Célszerű index.php nevet adni a fájlnak, ami a kezdő oldalunk, mert ha nem adjuk meg a mappán belül melyik fájlt olvassa be a böngésző, automatikusan az indexet keresi.
<?php
Első
lépésként érdemes azonnal a kapcsolati oldalt behúzni:
require("kapcsolat.php");
Használhatjuk
az inculde-ot is, de hiba esetén, igaz warning jelzést küld vissza, de attól
még minden más megjelenít, a requrie viszont nem engedi lefutni, és mivel ez egy
adatbázis alapú oldal és adatbázis kapcsolat nélkül nincs értelme, ezért jobb
ha ezt használjuk a kapcsolathoz.
Viszont
ha modulokat készítünk (pl: naptár, vagy szavazó fül), vagy cms rendszert
készítünk, akkor includ-al a lehalt modul nélkül is vígan tovább dolgozik a php
értelmező és nincs probléma belőle.
Tehát
ez dönti el, hogy include-ot vagy require-t használjunk inkább.
Űrlap
kereső mező:
· conditional
vagy más néven ternary operátor használata;
· a
% az sql joker karatere, ami előtt bármi lehet, ami mögött bármi lehet,
szótördékkel is tudunk keresni;
· '%{$kifejezes}%'
ezzel a megadással, ezt megadhatjuk minden sorra miben keressen, névben,
cégnévben, mobilszámban, e-mailben.
Ha
csak egy táblából kell beolvasnunk, akkor elég csak azt az egyet megadni. A
csillaggal minden oszlopot ki tudunk szelektálni a táblából, érdemes ezt
használni, mivel kisebb a hiba lehetőség, hogy nem írjuk el az oszlop neveket.
$kifejezes =
(isset($_POST['kifejezes'])) ? $_POST['kifejezes'] : "";
$sql = "SELECT *
FROM
tábla neved, ha egyből kell beolvasni
WHERE
(
nev
LIKE '%{$kifejezes}%'
OR
cegnev LIKE '%{$kifejezes}%'
OR
mobil LIKE '%{$kifejezes}%'
OR
email LIKE '%{$kifejezes}%'
)
ORDER
BY nev ASC"; //felveszünk egy sql változót
$eredmeny = mysqli_query($dbconn,
$sql);
Mindenképpen
érdemes soronként elválasztani, ami csak abból a szempontból érdekes, nehogy
valami kimaradjon. Írhatjuk egy sorba is, de úgy nem tűnik annyira fel, ha
lemarad egy % jel. Ennek még továbbra sincs kimenete, viszont itt készül egy
lekérés, készül egy eredmény, amit beteszünk egy eredmény nevű változóba
$kimenet = "";
/**
* mysqli_fetch -ebből többféle is van
* meghatározhatom, hogy a visszatérő adataim
az adatbázisból milyenfajta elrendezéssel készüljenek el:
* pl ha az eredmény az egy zsák krumpli, és ha
abból csinálunk egy fetch_array-t az egy tömb, ami lehet egy indexelt tömb,
vagy egy asszociatív tömb, tehát vagy egy oszlopszámmal hivatkozok rá, hogy
0-ik, első vagy második oszlop, vagy pedig egy cimkével, ami azt jelenti,hogy
név, cégnév, email vagy telefon. Ha az array-t használjuk, az legyártja
mindkétfajta tömböt, az indexelt tömböt is és az asszociatív tömböt is.
* Viszont ha nem szeretnénk dupla annyi
adatot, ezért vagy az assoc-al társításos tömböt, vagy a row-al sima indexelt
tömböt, a field-el pl mezőneveket lehetne lekérni, de arra most nincs
szükség.
* Tehát ha leírjuk, hogy fetch_assoc és
kitesszük a zárójeleket kiírja mire van szüksége, méghozzá a mysqli eredményére
ezért beküldjük neki: még ennek sincs
eredménye így betesszük egy sor nevű változóba, de még ezzel a sorral sem
nagyon tudunk mit kezdeni,
* ha ki akarnánk íratni, akkor a print
$sor['mobil']; paranccsal tudnánk egy egy sort kiírtani. Ezzel a tömbben lévő
egy adat kiírható.
* $sor =
mysqli_fetch_assoc($eredmény);
* print_r($sor);
*
a print r -el tömb nézetet kérhetünk, és ezzel megnézhetjük, hogy adatot
amit kapunk, hogy néz ki a valóságban;
* ctrl + u = megjeleníti a forrást egy új
oldalon
* $sor = mysqli_fetch_row($eredmény);
* print_r($sor);
*
és ctr+u egészen más eredményt fog adni, érdemes az array-el is
kipróbálni,amivel látható, hogy ebben az esetben megvan az indexelt és
asszociatív változat is, ahol gyakorlatilag kétszer annyi adatmennyiség jön le
a szerverről. Tehát ha csak az assocot használjuk akkor csak a neves
oszlopnevek jönnek le. * */
while ($sor =
mysqli_fetch_assoc($eredmeny)) {
/**
a html-ből bele másolhatjuk a kimenetbe a kódot, csak az idézőjeleket le kell
védeni, és némiképp kiegészíteni a kódot a $sor-al.
* Mivel nem egy db adatunk van az
adatbázisban, hanem több, ezért lesz szükségünk egy előltesztelős ciklusra, ami
azt jelenti, hogy ha egy feltétel teljesül,
akkor a mögötte lévő utasításblokk ismétlődik. Ezért a while (feltétel)
előltesztelős ciklust használjuk. Ami azt jelenti, hogy amíg én sorokat tudok
készíteni a rendszerből, addig a göndör zárójel közötti utasításblokk fog
végrehajtódni, gyakorlatilag ez fog ismételgetődni. Ha a $kimenet = elé nem
teszünk egy pontot, akkor csak az utolsó adatsort fogja megjeleníteni, a többit
lenyeli, ahogy a while ismétlődik és csak az utolsó marad benne a rendszerben.
Azért, hogy ne ez történjen nem egyenlőség, hanem hozzáfűzés kell, hogy
történjen. Viszont a php nem szereti ha egy változót nem deklarálunk, csak
hozzá fűzzük a nem létezőhöz, ezért a while ciklus előtt deklarálni kell.
Megcsinálja a névjegyeket, csak hibát dobna ki enélkül, hogy undefinied
variable, azaz nem létező változó.
* Így néz ki egy szerver oldali megoldás, amit
akár sablonként is lehet használni. */
$kimenet.=
"<article>
<h2>{$sor['nev']}</h2>
<h3>{$sor['cegnev']}</h3>
<p>Mobil:
<a
href=\"tel:{$sor['mobil']}\">{$sor['mobil']}</a></p>
<p>E-mail:
<a
href=\"mailto:{$sor['email']}\">{$sor['email']}</a></p>
</article>\n";
}
?><!DOCTYPE html>
<html>
<head>
<meta
charset="utf-8">
<title>Oldal neve</title>
<link href="stilus.css"
rel="stylesheet">
</head>
<body>
<h1>Oldal neve</h1>
<!--kereső form, a post method
láthatatlan módon küldi el az adatokat, a bodyban küldi az adatokat, nem mint a
get ami az urlben küldi az adatokat
az action a saját magát lehívó
rész-->
<form method="post"
action="">
<!-- a search kereső mező, ami
enterrel aktiválható, tehát nem kell elküldő gomb, csak egy enter, másrészt
szemantikusan jelzi, hogy ez egy kereső mező, ami a html5 újdonsága szintén,
azok a bönészők, amik ezt nem ismerik, text típusúra butítják vissza, és
ugyanúgy használható marad
kell adni neki egy id -t és a régebbi
böngészők kedvéért egy name attribútumot is, ha nem adjuk meg a name-t akkor is
működni fog-->
<input
type="search" id="kifejezes" name="kifejezes">
</form><div
class="container">
<?php print $kimenet;
?>
</div>
</body>
</html>
Nincsenek megjegyzések:
Megjegyzés küldése