affichage des résultats d'une recherche dans la base
Bonjour,
J'aimerais afficher les résultats de plusieurs requêtes (j'utilise mysql) sur plusieurs pages. Pour l'instant j'ai réussi à afficher les résultats dans l'ordre que je souhaite en utilisant 3 requêtes différentes seulement tous les résultats s'affichent sur une seule et même page. Pourriez vous m'aider à afficher les résultats sur plusieurs pages. Voici mon code :
Code:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71
|
if(!isset($_GET['page']))
{
$page = 1;
}
else
{
$page = $_GET['page'];
}
$max_results = 10;
$from = (($page * $max_results) - $max_results);
$sql = mysql_query("SELECT champ1, champ2, champ3 FROM
matable WHERE champ1 ='video' ORDER BY date DESC LIMIT $from, $max_results");
while ($row = mysql_fetch_array($sql)){
j'affiche les résultats de la 1ère requête
}
$sql = mysql_query("SELECT champ1, champ2, champ3 FROM
matable WHERE champ1 ='photo' ORDER BY date DESC LIMIT $from, $max_results");
while ($row = mysql_fetch_array($sql)){
j'affiche les résultats de la 2ème requête à la suite de la 1ère
}
$sql = mysql_query("SELECT champ1, champ2, champ3 FROM
matable WHERE champ1 ='texte' ORDER BY date DESC LIMIT $from, $max_results");
while ($row = mysql_fetch_array($sql)){
j'affiche les résultats de la 3ème requête à la suite de la 2ème
}
// J'affiche le nombre de page
$total_results = mysql_result(mysql_query("SELECT COUNT(*) as
Num FROM stallions"),0);
$total_pages = ceil($total_results / $max_results);
echo "<center><p><strong>";
if($page > 1){
$prev = ($page - 1);
echo "<a href=\"".$_SERVER['PHP_SELF']."?page=$prev\">Précédente</a> ";
}
for($i = 1; $i <= $total_pages; $i++){
if(($page) == $i){
echo "$i ";
} else {
echo "<a href=\"".$_SERVER['PHP_SELF']."?page=$i\">$i</a> ";
}
}
if($page < $total_pages){
$next = ($page + 1);
echo "<a href=\"".$_SERVER['PHP_SELF']."?page=$next\">Suivante</a>";
} |
Merci d'avance pour votre aide