Précédent   Forum des professionnels en informatique > PHP > Langage
Langage Forum sur le langage PHP, la POO, les conventions, la sécurité, etc. Avant de poster : FAQ Langage, toutes les FAQ PHP, cours langage et sources PHP
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 09/02/2012, 15h14   #1
Invité de passage
 
Homme
Étudiant
Inscription : juillet 2011
Messages : 26
Détails du profil
Informations personnelles :
Sexe : Homme
Localisation : France

Informations professionnelles :
Activité : Étudiant
Secteur : Arts - Culture

Informations forums :
Inscription : juillet 2011
Messages : 26
Points : 0
Points : 0
Par défaut limiter à 50 messages une boite mail

Bonjour,

J'utilise le code qui suit pour afficher des messages personnels. Il y a une limite de 20 messages pas pages. Si j'ai 1000 messages j'aurai donc 50 pages, ce qui à la longue peut entrainer du temps au chargement.

Je voudrais donc limiter l'affichage à 50 messages donc mettre un ORDER BY DESC LIMIT 50, mais je ne sais pas trop ou l'employer.

Merci pour votre aide.

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
 
//NOMBRE DE ROWS PAR PAGES
		define("NB_ROW_PAR_PAGE", 20);
 
		//COUNT IDmessage de $account pour préparer le calcul des pages
		$req = mysql_query("SELECT COUNT(IDmessage) AS total FROM `messagerie` WHERE Pour=".$account"");	
		$row = mysql_fetch_array($req);
		$num_rows = $row['total'];
		$nb_pages_total = ceil($num_rows/NB_ROW_PAR_PAGE);
 
		//CALCUL PAGES ET ROWS
		if(isset($_GET['page']) AND is_numeric($_GET['page']) AND $_GET['page'] > 0 AND $_GET['page'] <= $nb_pages_total)
		{
			$page_num = $_GET['page'];
			$start_row = $page_num * NB_ROW_PAR_PAGE;
			$start_row -= NB_ROW_PAR_PAGE;
		}
		else
		{
			$page_num = 1;
			$start_row = 0;
		}
		$text_limit_query = "LIMIT ".$start_row.", ".NB_ROW_PAR_PAGE."";
		mysql_free_result($req);
 
		//SELECT et affichage des messages
		$req = mysql_query("SELECT tp.Nom Expediteur, tm.*  FROM `compte` tp RIGHT JOIN `messagerie` tm ON tm.De = tp.ID WHERE tm.Pour=".$account" ORDER BY tm.IDmessage DESC $text_limit_query");
		while($msg = mysql_fetch_assoc($req))
		{
			// code
		}
		mysql_free_result($req);
maloy est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 09/02/2012, 15h24   #2
Responsable Développement Web

 
Avatar de Bovino
 
Homme Didier Mouronval
Développeur Web
Inscription : juin 2008
Messages : 13 808
Détails du profil
Informations personnelles :
Nom : Homme Didier Mouronval
Âge : 41
Localisation : France, Gironde (Aquitaine)

Informations professionnelles :
Activité : Développeur Web
Secteur : High Tech - Éditeur de logiciels

Informations forums :
Inscription : juin 2008
Messages : 13 808
Points : 35 787
Points : 35 787
Citation:
Code :
define("NB_ROW_PAR_PAGE", 20);


En même temps, c'était compliqué : il faut regarder la première ligne
__________________
Pas de question technique par MP !
Tout le monde peut participer à developpez.com, vous avez une idée, contactez-moi !
Vous possédez un blog et aimeriez diffuser vos billets sur le forum, contactez-moi !
Mes formations video2brain : La formation complète sur JavaScriptJavaScript et le DOM par la pratiquePHP 5 et MySQL : les fondamentaux
Mon livre sur jQuery
Bovino est actuellement connecté   Envoyer un message privé Réponse avec citation 10
Vieux 09/02/2012, 16h06   #3
Invité de passage
 
Homme
Étudiant
Inscription : juillet 2011
Messages : 26
Détails du profil
Informations personnelles :
Sexe : Homme
Localisation : France

Informations professionnelles :
Activité : Étudiant
Secteur : Arts - Culture

Informations forums :
Inscription : juillet 2011
Messages : 26
Points : 0
Points : 0
En faite je me suis peut être mal expliqué, je voudrai afficher en tout les 50 derniers messages, pas 50 messages par pages.
maloy est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 09/02/2012, 16h11   #4
Responsable Développement Web

 
Avatar de Bovino
 
Homme Didier Mouronval
Développeur Web
Inscription : juin 2008
Messages : 13 808
Détails du profil
Informations personnelles :
Nom : Homme Didier Mouronval
Âge : 41
Localisation : France, Gironde (Aquitaine)

Informations professionnelles :
Activité : Développeur Web
Secteur : High Tech - Éditeur de logiciels

Informations forums :
Inscription : juin 2008
Messages : 13 808
Points : 35 787
Points : 35 787
Arf... effectivement, j'avais pas compris comme ça !

Dans ce cas, modifie ce passage:
Code :
ORDER BY tm.IDmessage DESC
__________________
Pas de question technique par MP !
Tout le monde peut participer à developpez.com, vous avez une idée, contactez-moi !
Vous possédez un blog et aimeriez diffuser vos billets sur le forum, contactez-moi !
Mes formations video2brain : La formation complète sur JavaScriptJavaScript et le DOM par la pratiquePHP 5 et MySQL : les fondamentaux
Mon livre sur jQuery
Bovino est actuellement connecté   Envoyer un message privé Réponse avec citation 00
Vieux 09/02/2012, 18h02   #5
Invité de passage
 
Homme
Étudiant
Inscription : juillet 2011
Messages : 26
Détails du profil
Informations personnelles :
Sexe : Homme
Localisation : France

Informations professionnelles :
Activité : Étudiant
Secteur : Arts - Culture

Informations forums :
Inscription : juillet 2011
Messages : 26
Points : 0
Points : 0
oui merci, en faite je l'avais déjà fait, mais il se pose un problème, car maintenant j'affiche 50 messages mais le count du 1er select est calculé sur mon total de messages donc j'ai des pages 1-2-3... en doublons.

Il faudrait dire au 1er SELECT, trouver le total des messages dans une limite de 50 messages, si j'en ai 10, il m'en trouve 10, mais si j'en ai 150 il me trouve les 50 derniers.
maloy est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 09h34.


 
 
 
 
Partenaires

Hébergement Web