Diskuze: Mechanismus zpráv v chatu
V předchozím kvízu, Online test znalostí PHP, jsme si ověřili nabyté zkušenosti z kurzu.

Člen

Zobrazeno 16 zpráv z 16.
//= 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.
Tak použij dotaz:
$zpravy = Db::dotazVsechny('SELECT *
FROM chat
ORDER BY zprava_id ASC');
To je správně. Tenhle dotaz vrátí první 20 zpráv a hotovo. Pokud chceš
někam přidávat nějaké další zprávy, musíš položit další dotaz/y
nebo tenhle adekvátně upravit. Vše se logicky odvíjí od toho, co to má
vlastně ve výsledku dělat...
$zpravy = Db::dotazVsechny('SELECT *
FROM chat
ORDER BY zprava_id DESC LIMIT 20');
Mělo by to fungovat
Proč sem píšeš něco, co se dá složit z původní (nechtěné) a poslední verze?
A jak, jelikož když tam bude ASC a LIMIT 20, tak se zobrazí 20 prvních zpráv a poslední se nepřidají. Když tam bude DESC, tak se zobrazí, ale ze shora dolu. Ja potřebuji, aby se zobrazilo 20 zpráv ze zdola nahoru, tudíž aby nejnovější zprávy byly dole.
Na co to byla reakce? Znáš tlačítko <i>Odpovědět</i>?
Hledal jsem docela dlouho, ale nic jsem nenašel, proto jsem šel sem.
Promiň, ale první dotaz na google a: http://php.net/…-reverse.php
foreach($zpravy as array_reverse($zprava))
echo($zprava['zprava']);
Spatne je, ze to primo echujes. Ukladej to do promenne, echuj na zaver. (ledaze bys chtel setrit pamet) Pak s tim muzes snadno carovat.
$str = '';
foreach ($zpravy as $zprava) $str = $str . $zprava['zprava'];
echo $str;
// ---
$str = '';
foreach ($zpravy as $zprava) $str = $zprava['zprava'] . $str; // reverzni
echo $str;
Je mozne pouzit dvojity sql dotaz
SELECT * FROM (SELECT ... LIMIT 20) x ORDER BY x.neco DESC
Zobrazeno 16 zpráv z 16.