PDA

View Full Version : [MySQL] visualizzare un numero tot di messaggi


bouncey2k
19-12-2007, 23:31
Supponiamo di avere all'interno del mio database un tot di messaggi, tipo 200.

Se nella mia pagina decido di mostrare solo gli ultimi 5 messaggi - quindi con (LIMIT 0,5) e in ordine decrescente - come faccio a fare un link che mi mostri una pagina con i seguente 20 messaggi? E i precedenti 20?

vizzz
20-12-2007, 09:34
Supponiamo di avere all'interno del mio database un tot di messaggi, tipo 200.

Se nella mia pagina decido di mostrare solo gli ultimi 5 messaggi - quindi con (LIMIT 0,5) e in ordine decrescente - come faccio a fare un link che mi mostri una pagina con i seguente 20 messaggi? E i precedenti 20?

di che linguaggio stiamo parlando? php?
comunque in linea teorica devi modificare ogni volta la query a seconda dei parametri che passi via link.

kk3z
20-12-2007, 10:04
fai la query aggiungendo SQL_CALC_FOUND_ROWS che calcola il numero di record senza tenere conto del limite:
SELECT SQL_CALC_FOUND_ROWS campo1, campo2
FROM tabella
WHERE 1+1 = 2
LIMIT $a_partire_dal_record_numero, $quanti_record_per_pagina

Quindi fai una nuova query per trovare il numero calcolato da mysql
SELECT FOUND_ROWS() count

Quindi fai un po' di calcoli. Questa è la funzione che uso di solito:

$count è il numero di record che ricavi con la select FOUND_ROWS()
$per_page è $quanti_record_per_pagina
$start_from è $a_partire_dal_record_numero

function page_links($link, $count, $per_page, $start_from)
{
if ($count > $per_page)
{
echo "<br><div align='right'>Pagina: ";
{
$current_page = ceil($start_from / $per_page)+1;
$page_count = ceil($count / $per_page)+1;

if ($current_page > 11)
if ($page_count > 50)
echo "<a href='$link'>&lt;&lt;</a> ";

for ($page = 1; $page < $page_count; $page++)
{
if ($page_count > 50)
{
if ($page < $current_page-10 || $page > $current_page+10)
continue;
}

if ($page == $current_page)
{
echo "<span style='padding:2px; border:1px solid white;'>";
echo $page;
echo "</span>";
}
else
{
$start_from = ($page-1) * $per_page;
echo "<a href='$link&amp;start_from=$start_from'>$page</a>";
}

if ($page < $page_count-1)
echo " ";
}

if ($current_page < $page_count-11)
if ($page_count > 50)
echo " <a href='$link&amp;start_from=".(($page_count-2)*$per_page)."'>&gt;&gt;</a>";
}
echo "</div><br>";
}
}