Diskuze: Výpis z db
V předchozím kvízu, Online test znalostí PHP, jsme si ověřili nabyté zkušenosti z kurzu.

Člen

Zobrazeno 24 zpráv z 24.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Online test znalostí PHP, jsme si ověřili nabyté zkušenosti z kurzu.
Jestli chyba = vypisuje to jen jeden řádek, pak musíš to mysql_fetch_assoc() hodit do cyklu (nevim, jak to funguje s foreach, ale u tohohle je zvykem dávat while).
while ($vysledek =mysql_fetch_assoc($poznamka)) {
echo "odkaz";
}
Jo, pardon zapomněl jsem tam připsat tu chybu.
Ta chyba je: **Warning: mysql_fetch_assoc() expects parameter 1 to be resource,
boolean given in C:\Users\j\Desktop\PHP\hl-stranka.php on line 22
Warning: Invalid argument supplied for foreach() in C:\Users\j\Desktop\PHP\hl-stranka.php on line 23**
Ahoj, chyba nastává proto, protože je očekáván odkaz na tabulku (resource), ale dostalo to false (boolean). Proč? Dotaz, který jsi spustil je chybný a proto bylo navráceno false, nikoli resource.
V tom dotazu, ta poslední věc by měla být v uvozovkách, když to opravíš, dotaz by měl být správný a již by to nemělo vracet false.
$poznamka = mysql_query("SELECT * FROM poznamky WHERE nadpis LIKE '$vyhledanynadpis'");
Nezapomeň, že funkce mysql_fetch_assoc ti navrátí jen jeden řádek a při procházení získáváš jednotlivá políčka tabulky. Když tak využij skript od Martina.
Ještě jedna věc, tento ovladač je zastaralý a bude v budoucnu
odstraněný. Použij novější
Co tím myslíš? jaký ovladač? jako mysql? místo mysqli?
No že funkce typu mysql_ by se neměly používat. Můžeš místo nich použít velice podobné mysqli_ nebo PDO...
Funguje ti už ten skript?
Nevím, co vše jsi změnil. V tom tvém původním skriptu máš ještě jednu chybu, ve foreachu používáš $poznamky a také $poznamka..
No to vím, ale tak ta $poznamka je dobře ale nevím co mám dělat s tou $poznamky.. to tam mam dát $poznamky=10;? a bude to procházet 10x? Muj kod je ted takový:
<html>
<head>
<link rel="stylesheet" href="styl-index.css" type="text/css" />
</head>
<body>
<article>
<form action="hl-stranka.php" method="get">
<input type="text" placeholder="Vyhledejte poznámku dle nadpisu" class="vyhledani" name="vyhledanynadpis">
<input type="image" src="vyhledat.png" class="vyhledat">
<p class="poznamky"> Poznámky </p>
<?php
$link = mysql_connect("localhost", "root", "your_password");
mysql_select_db('internetove-poznamky',$link);
if (isset ($_GET["vyhledanynadpis"]))
{
$vyhledanynadpis = "%" . mysql_real_escape_string( $_GET['vyhledanynadpis'], $link) . "%";
$poznamka = mysql_query("SELECT * FROM poznamky WHERE nadpis LIKE '$vyhledanynadpis'");
$vysledek = mysql_fetch_assoc($poznamka);
foreach($vysledek as $poznamky)
{
echo('<h2><a href="zobrazenipoznamky.php?poznamka=' . htmlspecialchars($poznamka['url']) . '"></a></h2>');
}
}
?>
</article>
</body>
</html>
Je to celé, pro lepší hledání chyby
echo('<h2><a href="zobrazenipoznamky.php?poznamka=' . htmlspecialchars($poznamka['url']) . '"></a></h2>');
Toto je řádek z tvého cyklu foreach($vysledek as $poznamky). Nemá tedy být ve výše zmíněném kódu spíše $poznamky['url'] místo $poznamka['url']?
No, asi ano ale teď mi to píše:
Warning: Illegal string offset 'url' in C:\Users\j\Desktop\PHP\hl-stranka.php
on line 25.
Zadal jsem do inputu písmeno a.
V DB mám záznamy(podle nadpisu, protože se to má hledat dle nadpisu): as,
ahojka, amsamle, anglictina
a co tohle?
$poznamka = mysql_query("SELECT * FROM poznamky WHERE nadpis LIKE '$vyhledanynadpis'");
while($vysledek=mysql_fetch_array($poznamka))
{
echo('<h2><a href="zobrazenipoznamky.php?poznamka=' . htmlspecialchars($vysledek['url']) . '"></a></h2>');
}
Do budoucna je ale opravdu dobré přejít na novější (bezpečnější) ovladače mysqli_ resp. PDO. Mě se moc líbil a používám již hodtový "databázový wrapper", snad jsem to nazval dobře, který jsem tady objevil v rámci jednoho seriálu o databázích: http://www.itnetwork.cz/…sql-ovladace
nech si ještě vypsat obsah proměnné $_GET['vyhledanynadpis']. Otázkou totiž zůstává, co přesně obsahuje a co je tedy výsledným obsahem lokální proměnné $vyhledanynadpis, která je součástí dotazu.
Dej si napřed do dotazu "natvrdo" za LIKE nějaký textový řetězec, např, to písmeno "a" místo proměnné a zjisti, jestli ti teď něco vrátí databáze.
Výsledek je žádný. A kod vypadá takhle, snad jsem tě dobře pochopil
$vyhledanynadpis = "%" . mysql_real_escape_string( $_GET['vyhledanynadpis'], $link) . "%";
$poznamka = mysql_query("SELECT * FROM poznamky WHERE nadpis LIKE 'a'");
while($vysledek=mysql_fetch_array($poznamka))
{
echo('<h2><a href="zobrazenipoznamky.php?poznamka=' . htmlspecialchars($vysledek['url']) . '"></a></h2>');
}
Edit: po vložení %a% to stejně nic nedělá, takže je problém asi někde po téhle části. Nebo spíš před ní?
SELECT * FROM poznamky WHERE nadpis LIKE '%a%'
Nezapomeň na ty znaky "procenta".
Jojo, přečetl jsem si to až potom. Je to tam doplněné pod slovem Edit.
Ale to je jedno opět to
nic nedělá. Já opravdu netuším kde je chyba. Myslel jsem si, že když to
udělám podle toho co je tady na webu tak mi to konečne bude fungovat. Ale jak
vidím, tak asi ne .(
teď jsem si všimnul:
<a href="zobrazenipoznamky.php?poznamka=' . htmlspecialchars($vysledek['url']) . '"></a>
Vždyť ty nemáš nic (text) mezi značkami
<a> </a>
Zkus toto:
<a href="zobrazenipoznamky.php?poznamka=' . htmlspecialchars($vysledek['url']) . '">'.$vysledek['url'].'</a>
pomohlo to? podle mě totiž něměl skript co vypsat na obrazovku
Zobrazeno 24 zpráv z 24.