begin process at 2010 09 03 10:06:09
  Trouver un code source :
 
dans
 
Accueil > 

Code

 > 

Astuces

 > PAGINER LES RÉSULTATS D'UNE REQUÊTE

PAGINER LES RÉSULTATS D'UNE REQUÊTE


 Information sur la source

Note :
9,5 / 10 - par 2 personnes
9,50 / 10

  • 1

  • 2

  • 3

  • 4

  • 5

  • 6

  • 7

  • 8

  • 9

  • 10
Catégorie :Astuces Classé sous :requete, paginer, résultat Niveau :Expert Date de création :26/04/2002 Date de mise à jour :26/04/2002 15:25:14 Vu / téléchargé :11 827 / 179

Auteur : Skyride

Ecrire un message privé
Commentaire sur cette source (4)
Ajouter un commentaire et/ou une note

 Description

Voici un petit code source qui vous permettra de paginer en numéro de pages les résultats que vous renvoie une requête.
Vous pouvez spécifier :
- le nombre de résulats par page
- le nombre de numero de pages affichées
          

Source

  • <HTML>
  • <HEAD>
  • <link rel="stylesheet" type="text/css" href="style.css">
  • </HEAD>
  • <!-- Requête de sélection des produits -->
  • <cfquery name="listproduit" datasource="pagination">
  • SELECT * FROM PRODUIT
  • </cfquery>
  • <!-- A vous de paramétrer ces 2 variables -->
  • <cfset NbNumberPage = 5> <!-- Nombre de numéros de pages affichées -->
  • <cfset NbEnregByPage = 10> <!-- Nombre d'enregistrements par page -->
  • <cfset NbPage = (listproduit.recordcount \ NbEnregByPage)>
  • <cfif #evaluate(listproduit.recordcount mod NbEnregByPage)# is not 0>
  • <cfset NbPage = NbPage + 1>
  • </cfif>
  • <cfset url.corps="cf_produit_liste.cfm">
  • <cfif IsDefined('url.page')>
  • <cfset recherche_debut=((url.page-1)*NbEnregByPage)+1>
  • <cfelse>
  • <cfset recherche_debut=1>
  • <cfset url.page = 1>
  • </cfif>
  • <cfoutput>URL PAGE : #url.page#</cfoutput>
  • <BODY bgcolor=white vlink=gray alink=gray>
  • <font face="Verdana, Arial, Helvetica, sans-serif">
  • <cfif listproduit.recordcount GT 0>
  • <center>
  • <cfoutput>
  • Page #url.page# / #NbPage#<br><br>
  • <font color="red">#listproduit.recordcount# produits(s) trouvé(s)</font><br><br>
  • </cfoutput>
  • <cfif url.page GT NbNumberPage>
  • <cfoutput>
  • <a href="#CGI.PATH_INFO#?corps=#url.corps#&page=#Evaluate((((url.page\NbNumberPage)*NbNumberPage)+1) - NbNumberPage)#"><b>[<<]</b></a>
  • </cfoutput>
  • </cfif>
  • <cfif url.page GT 1>
  • <cfoutput>
  • <a href="#CGI.PATH_INFO#?corps=#url.corps#&page=#Evaluate(url.page - 1)#"><b>[<]&nbsp;</b></a>
  • </cfoutput>
  • </cfif>
  • <cfif listproduit.recordcount GT NbEnregByPage>
  • <cfoutput>
  • <cfloop index="curpg" from="#Evaluate(((url.page\NbNumberPage)*NbNumberPage)+1)#" to="#Evaluate((((url.page\NbNumberPage)+1)*NbNumberPage))#" step="1">
  • <cfif listproduit.recordcount gt (curpg - 1) * NbEnregByPage>
  • <cfif curpg is not url.page>
  • <a href="#CGI.PATH_INFO#?corps=#url.corps#&page=#curpg#">[#curpg#]</a>
  • <cfelse>
  • [#curpg#]
  • </cfif>
  • </cfif>
  • </cfloop>
  • </cfoutput>
  • </cfif>
  • <cfif url.page * NbEnregByPage lt listproduit.recordcount>
  • <cfoutput>
  • <a href="#CGI.PATH_INFO#?corps=#url.corps#&page=#Evaluate(url.page + 1)#"><b>[>]</b></a>
  • </cfoutput>
  • </cfif>
  • <cfif (url.page\NbNumberPage) lt (listproduit.recordcount\(NbEnregByPage*NbNumberPage))>
  • <cfoutput>
  • <a href="#CGI.PATH_INFO#?corps=#url.corps#&page=#Evaluate((((url.page\NbNumberPage)+1)*NbNumberPage)+1)#"><b>[>>]</b></a>
  • </cfoutput>
  • </cfif><br><br><br>
  • <cfoutput query="listproduit" startrow="#recherche_debut#" maxrows="#NbEnregByPage#">
  • Réference : #PROD_ID#<br>
  • </cfoutput>
  • </center>
  • </cfif>
  • </FONT>
  • </BODY>
  • </HTML>
<HTML>
<HEAD>
	<link rel="stylesheet" type="text/css" href="style.css">
</HEAD>

<!-- Requête de sélection des produits -->
<cfquery name="listproduit" datasource="pagination">
	SELECT * FROM PRODUIT
</cfquery>

<!-- A vous de paramétrer ces 2 variables -->
<cfset NbNumberPage = 5>	<!-- Nombre de numéros de pages affichées -->
<cfset NbEnregByPage = 10>	<!-- Nombre d'enregistrements par page -->

<cfset NbPage = (listproduit.recordcount \ NbEnregByPage)>

<cfif #evaluate(listproduit.recordcount mod NbEnregByPage)# is not 0>
	<cfset NbPage = NbPage + 1>
</cfif>

<cfset url.corps="cf_produit_liste.cfm">
	
<cfif IsDefined('url.page')>
	<cfset recherche_debut=((url.page-1)*NbEnregByPage)+1>
<cfelse>
	<cfset recherche_debut=1>
	<cfset url.page = 1>
</cfif>
<cfoutput>URL PAGE : #url.page#</cfoutput>

<BODY bgcolor=white vlink=gray alink=gray>
	<font face="Verdana, Arial, Helvetica, sans-serif">
		<cfif listproduit.recordcount GT 0>
			<center>
				<cfoutput>
					Page #url.page# / #NbPage#<br><br>
					<font color="red">#listproduit.recordcount# produits(s) trouvé(s)</font><br><br>
				</cfoutput>
						
				<cfif url.page GT NbNumberPage>
					<cfoutput>
						<a href="#CGI.PATH_INFO#?corps=#url.corps#&page=#Evaluate((((url.page\NbNumberPage)*NbNumberPage)+1) - NbNumberPage)#"><b>[<<]</b></a>
					</cfoutput>
				</cfif>
								
				<cfif url.page GT 1>
					<cfoutput>
						<a href="#CGI.PATH_INFO#?corps=#url.corps#&page=#Evaluate(url.page - 1)#"><b>[<]&nbsp;</b></a>
					</cfoutput>
				</cfif>
								
				<cfif listproduit.recordcount GT NbEnregByPage>
					<cfoutput>
						<cfloop index="curpg" from="#Evaluate(((url.page\NbNumberPage)*NbNumberPage)+1)#" to="#Evaluate((((url.page\NbNumberPage)+1)*NbNumberPage))#" step="1">
							<cfif listproduit.recordcount gt (curpg - 1) * NbEnregByPage>
								<cfif curpg is not url.page>
									<a href="#CGI.PATH_INFO#?corps=#url.corps#&page=#curpg#">[#curpg#]</a>
								<cfelse>
									[#curpg#]
								</cfif>
							</cfif>
						</cfloop>
					</cfoutput>
				</cfif>
								
				<cfif url.page * NbEnregByPage lt listproduit.recordcount>
					<cfoutput>
						<a href="#CGI.PATH_INFO#?corps=#url.corps#&page=#Evaluate(url.page + 1)#"><b>[>]</b></a>
					</cfoutput>
				</cfif>
				
				<cfif (url.page\NbNumberPage) lt (listproduit.recordcount\(NbEnregByPage*NbNumberPage))>
					<cfoutput>
						<a href="#CGI.PATH_INFO#?corps=#url.corps#&page=#Evaluate((((url.page\NbNumberPage)+1)*NbNumberPage)+1)#"><b>[>>]</b></a>
					</cfoutput>
				</cfif><br><br><br>
				
				<cfoutput query="listproduit" startrow="#recherche_debut#" maxrows="#NbEnregByPage#">
					Réference : #PROD_ID#<br>
				</cfoutput>
			</center>
		</cfif>
	</FONT> 
</BODY>
</HTML>           

 Conclusion

Comme d'habitude, si vous avez des améliorations, n'hésitez pas à m'en faire part ;-)          

 Fichier Zip

Les Membres Club peuvent télécharger directement un fichier contenu dans le zip sans télécharger le zip en entier !

Télécharger le zip


 Sources du même auteur

Source avec Zip GESTION DYNAMIQUE DES PAGES MULTI-PAYS
Source avec Zip ARBORESCENCE DE FICHIERS
RESPECTER LA MISE EN FORME DANS UN CHAMPS DE TYPE TEXTAREA
REGROUPEMENT DE JEUX D'ENREGISTREMENTS SUR UN CHAMPS D'UNE T...
GESTION D'ABSENCE DE CONCORDANCE DE VALEURS ENTRE LES TABLES...

 Sources de la même categorie

CHANGER LA COULEUR D'UN TABLEAU UNE LIGNE SUR DEUX par Netchris
RÉCUPÉRATION DES MEMBRES D'UNE LISTE STATIQUE LDAP par chtit
CF_MEMO par BenLaKnet
FORMATAGE DE TEXTE (PRISE EN COMPTE DES RETOURS À LA LIGNE) par fw
MISE EN FORME D'UN CHAMP TEXT (DE TYPE PRÉNOM) par feedlog

 Sources en rapport avec celle ci

AFFICHER LE RESULAT D'UNE REQUETE SUR UNE BASE DE DONNÉES SU... par zah_zied
SIMPLE REQUETTE AVEC AFFICHAGE DES RÉSULTATS par fabrice69
CONNEXION ET REQUETTE SUR UNE BASE DE DONNÉES par fabrice69
REQUÊTE DE RECHERCHE AVEC ACCENTUATION DES MOTS par jeanwebh
CONDITIONS DANS LES REQUÈTES par jjn1er

Commentaires et avis

Commentaire de kani le 01/06/2002 15:38:07

Salut skyrid je suis debutant en la matiére et j'aesssaie d'utiliser le code source pour paginer une recherche mais ca bloque au niveau de #PROD_ID#. Le server m'envoie le msg d'erreur suivant: Error resolving parameter PROD_ID

"...ColdFusion was unable to determine the value of the parameter. This problem is very likely due to the fact that either:

You have misspelled the parameter name, or
You have not specified a QUERY attribute for a CFOUTPUT, CFMAIL, or CFTABLE tag.

The error occurred while processing an element with a general identifier of (#PROD_ID#), occupying document position (81:17) to (81:24)....". Je comprend la signification du message et je verifier l'ortho. du parametre qui est correctement écrit mais j'ai tjr ce messagge
merci

Commentaire de Skyride le 01/06/2002 21:14:43

Salut Kani
Afin de tester mon exemple, j'ai pris en condidération une table PRODUIT avec comme champs PROD_ID.
Afin de pouvoir rendre fonctionnel ce code, tu dois créer une base access avec une table PRODUIT et un champs de type integer PROD_ID

Voila

Bon courage

Commentaire de kamel_ le 18/03/2004 12:08:31

Salut

je te remercie bps pour ce code source pour la pagination, moi je rencontre un pb c est ke quand il m'affiche le resultat de ma requete : il affiche bien les [1][2][3]....mais qd je clique sur l une des page il affiche pas la suite des enregistrements et je sais pas pkoi.
je penses que c est du au url.corps, c koi exactement ca ?
Peux tu m aider merci.

Commentaire de je182th le 21/01/2008 12:22:32

Bonjour,

J'utilise cette source pour mon projet, mais je rencontre un problème...
En fait l'affiche de la requete à lieu grace a une liste déroulante :

fichier : search.cfm

<CFQUERY name="req" datasource="data">
SELECT *
from fonction
ORDER BY libelle_fonction
</CFQUERY>

<CFFORM method="post" action="result.cfm">
<CFSELECT query="req" name="fonction.id_fonction" value="id_fonction" display="Libelle_fonction">
</CFSELECT>
<input type="submit" value="Rechercher">
</CFFORM>

fichier result.cfm

<CFQUERY name="requete" datasource="data">
SELECT Libelle_offre, offre.Libelle_Fonction, Date_prop, Nom_Region
FROM Fonction, offre
WHERE fonction.Id_fonction=offre.id_fonction
And offre.Id_fonction=#fonction.id_fonction#
</CFQUERY>


voila l'erreur rencontrée:

Element ID_FONCTION is undefined in FONCTION.

The error occurred in C:\Program Files\xampp\htdocs\result.cfm: line 6

FROM Fonction, offre
WHERE fonction.Id_fonction=offre.id_fonction
And offre.Id_fonction=#fonction.id_fonction#
</CFQUERY>

 Ajouter un commentaire


Discussions en rapport avec ce code source dans le forum

Comment mettre une requete dans une variable [ par alf666666 ] J'aimerais mettre le r&#233;sultat d'une requete (ou je sais que le r&#233;sultat est unique) dans une variable pour pouvoir l'employer plus loin sur Affichage Requete dans un Combobox [ par alf666666 ] Bonjour, J'aimerais savoir comment faire pour afficher le r&#233;sultat d'une requete dans un combobox. Au lieu de tout noter en html en dur, comme le Requete SQL [ par alf666666 ] Je désire afficher sur mon site un classement. J'ai deux tables, une table hotel et une table note. Une personne met une note sur un hotel. Donc je d Ne pas afficher le résultat d'une fonction [ par mandaillou ] SalutJ'ai le code suivant&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;cfoutput&gt;#arrayAppend(tab_retour,det_rubr_finale.id_rubrique)#&lt;/cfoutput&gt;<FONT fac comment je peux formater une chaine de caractere que je recupere d'une requete pour supprimer tous les mots entre {} [ par kamel92400 ] bonjour a tous !je voulais savoir comment faire pour modifier une chaine de caractere que je recupere d'une requete:la chaine c celle l&#224;:{AbonNom Requete access [ par midoutun ] Je veux savoir comment faire&nbsp; une requ&#234;te &#224; partir d'un sous formulaire? Requete SQL sur plusieurs bases [ par secdeouf ] Bonjour, Je souhaite savoir s'il est possible de faire une requête sur plusieurs bases. En fait je souhaite faire une jointure sur 2 tables situées d Afficher 10 résultat de recherche par pages [ par gomezkarim ] Bonjour;Mon site est en Coldfusion et je veux  afficher 10 résultats de recherche par pages, Merci pour votre réponse. Calcul des valeurs d'un résultat ? [ par umutys ] Bonjour,je voulais savoir s'il était possible de calculer le résultat d'un champ ?Exemple : Un utilisateur met dans son pannier 2 tomates, 3 salades e Sauvegarder une requete query [ par Fabienduceps ] Slt, tout est dans la question , est il possible de sauvegarder le résultat d'un query , pour ensuite par exemple le modifier à sa guise avec des quer


Nos sponsors


Sondage...

Comparez les prix

CalendriCode

Septembre 2010
LMMJVSD
  12345
6789101112
13141516171819
20212223242526
27282930   

Consulter la suite du CalendriCode

 
Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel (EBArtSoft), Merci à Vincent pour ses précieux conseils.
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés

Google Coop CodeS-SourceS Google Coop CodeS-SourceS
Temps d'éxécution de la page : 0,827 sec (3)

Nous contacter | Annoncer sur CodeS-SourceS | Mentions légales