Mangeur de cigogne Hébergement du site en PHP et Mysql par WDMédia-hébergement
Vous aussi adpotez les éléPHPants de Vincent Pontier !


Rechercher dans le forum

Mots-clés :

Trouver :
un de ces termes tous les termes

Depuis :
7 j 15 j 30 j


Retour à l'index du forum

Requette sql : dernier et avant dernier

Message original de squal

Le : 30/06/2008 à 19:35:38

Dejà lu 205 fois avant vous

Bonjour,

Je souhaiterai afficher les 3 derniers ajout d'une table sql, sachant que chaque ajout possède un identifiant (id). Mais les ajout pouvant être supprimé, les id ne seront pas forcement les uns a la suites des autres. J'ai utilisé un id auto incrémenté ...

Exemple :
id : 1 dskljhsdkjghdflkgjh
id : 2 kjsdhskjf
id : 6 sdkjhfsjdkhf
id : 8 skjdfhjksdfh

Je voudrais donc que s'affiche uniquement :
id 8 , id 6, id 2 (les 3 derniers de la tables).

Pour cela j'ai utilisé un code un peu barbare (sans boucle while) que voici :

http://phpdebutant.org/wall0.php

Comme vous pouvez le voir, j'ai utiliser une requete qui utilise les limites ...

mais sa ne fonctionne pas comme je veux ...
la variable modele1 modele2 et modele3 sont 3 fois les mêmes ...

Merci d'avance pour votre aide ...

Re: Requette sql : dernier et avant dernier

Réponse de squal

Le : 30/06/2008 à 19:39:14

Apparament j'ai pas su correctement utiliser le wall donc je mais le code en direct ici :

.
//recuperation des donnees de la derniere annonce
                $rq = 'select distinct id from tbl_annonce Order by id DESC limit 0,1';
                $result = mysql_query($rq) or die ("Affichage annonce impossible");
                                      
                $sql = "select * from tbl_annonce where id='$id'";
                $req = mysql_query($sql) or die ("Affichage annonce impossible");
                $data = mysql_fetch_array($req);
                $id1 = $data['id'];
                $modele1 = $data['modele'];
                $prix1 = $data['prix'];
                                
                //recuperation des donnees de l'avant derniere annonce
                $rq = 'select distinct id from tbl_annonce Order by id DESC limit 1,1';
                $result = mysql_query($rq) or die ("Affichage annonce impossible");
                                      
                $sql = "select * from tbl_annonce where id='$id'";
                $req = mysql_query($sql) or die ("Affichage annonce impossible");
                $data = mysql_fetch_array($req);
                $id2 = $data['id'];
                $modele2 = $data['modele'];
                $prix2 = $data['prix'];
                
                //recuperation des donnees de l'avant avant derniere annonce
                $rq = 'select distinct id from tbl_annonce Order by id DESC limit 2,1';
                $result = mysql_query($rq) or die ("Affichage annonce impossible");
                                      
                $sql = "select * from tbl_annonce where id='$id'";
                $req = mysql_query($sql) or die ("Affichage annonce impossible");
                $data = mysql_fetch_array($req);
                $id3 = $data['id'];
                $modele3 = $data['modele'];
                $prix3 = $data['prix'];

Re: Requette sql : dernier et avant dernier

Réponse de Rafaelle

Le : 30/06/2008 à 20:10:58

Bonjour

Je ne vois pas l'intérêt, mais bon, pour le jeu intellectuel


<?php
$sql 
"select * from tbl_annonce ORDER BY id DESC LIMIT 0,1"
$req mysql_query($sql) or die ("Affichage annonce impossible");
$data mysql_fetch_array($req);
$id1 $data['id'];
$modele1 $data['modele'];
$prix1 $data['prix']; 

$sql "select * from tbl_annonce ORDER BY id DESC LIMIT 1,1"
$req mysql_query($sql) or die ("Affichage annonce impossible");
$data mysql_fetch_array($req);
$id1 $data['id'];
$modele1 $data['modele'];
$prix1 $data['prix']; 

$sql "select * from tbl_annonce ORDER BY id DESC LIMIT 2,1"
$req mysql_query($sql) or die ("Affichage annonce impossible");
$data mysql_fetch_array($req);
$id1 $data['id'];
$modele1 $data['modele'];
$prix1 $data['prix']; 
?>



Raf

Re: Requette sql : dernier et avant dernier

Réponse de Rafaelle

Le : 30/06/2008 à 20:23:21

Ou, pour que tu voies bien ton erreur :


<?php
$rq 
'select distinct id from tbl_annonce Order by id DESC limit 0,1';
$result mysql_query($rq) or die ("Affichage annonce impossible");
                                      
$sql "select * from tbl_annonce where id='".$result['id']."'";
$req mysql_query($sql) or die ("Affichage annonce impossible");
$data mysql_fetch_array($req);
$id1 $data['id'];
$modele1 $data['modele'];
$prix1 $data['prix']; 

//etc
?>

Re: Requette sql : dernier et avant dernier

Réponse de squal

Le : 01/07/2008 à 00:00:56

Dsl mais en fait je vois pas comment faire autrement ...
et pour ton dernier post, Rafaelle dsl mais je comprend tjs pas ...

Re: Requette sql : dernier et avant dernier

Réponse de squal

Le : 01/07/2008 à 00:02:58

Enfin si, j'ai bien compris que ma requete $rq ne selectionné aucun id ... mais comment faire alors ?

Re: Requette sql : dernier et avant dernier

Réponse de Maljuna Kris

Le : 01/07/2008 à 07:34:15

Saluton,
Je ne vois pas pourquoi tu ne fais pas une seule requête dont tu parcourrais les lignes de résultats avec une boucle ?
SELECT id, modele, prix FROM tbl_annonce ORDER BY id DESC LIMIT 3

Re: Requette sql : dernier et avant dernier

Réponse de Rafaelle

Le : 01/07/2008 à 07:48:32

Bonjour

Pour mon 2e post, ce que tu dois utiliser dans ta requête c'est $result['id'] et non $id ... Tu as testé mes propositions ?

Sinon, bien d'accord avec MK (comme d'hab') ... Pourquoi ne veux-tu pas de while ?

Raf

Re: Requette sql : dernier et avant dernier

Réponse de squal

Le : 01/07/2008 à 08:49:35

Alors ...

Pour les tests avec ".$result['id']." sa ne fonctionne pas ... ou je n'est pas sus le faire.

Sinon, je ne comprend pas comment je pourrais utiliser la boucle while sachant qu'il me faut absolument :
les variables $id1, $modele1, $prix1 puis pareil pour 2 et pareil pour 3.

Dans le cas ou je fais une boucle while, je serai obliger de m'en servir a se moment la, et pas plus tard, j'arrive
pas à m'expliquer ...

C'est pas comme si je faisais les choses à la suite, j'utilise les $1 puis j'affiche d'autre truc puis j'utilise les $2 puis j'affiche
des truc puis enfin j'utilise les $3 et puis arrive la suite de la page ...

Je sais pas si je suis clair, c'est tot aussi, ... lol

Re: Requette sql : dernier et avant dernier

Réponse de rafaelle

Le : 01/07/2008 à 09:10:57

Je suis allée trop vite ...


<?php
$rq 
'select distinct id from tbl_annonce Order by id DESC limit 0,1'
$result mysql_query($rq) or die ("Affichage annonce impossible"); 
$donnees=mysql_fetch_assoc($result);
$sql "select * from tbl_annonce where id='".$donnees['id']."''"
?>



Si tu dois réutiliser utilise un ou des array ...

<?php
$les_modeles
=array();
$les_prix=array();
//etc avec les autres données
$req=mysql_query("SELECT id, modele, prix FROM tbl_annonce ORDER BY id DESC LIMIT 3 ");
while(
$res=mysql_fetch_assoc($req)) {
$les_modeles[]=$res['modele'];
$les_prix[]=$res['prix'];
//etc
}

//puis dans ton scrpt
echo "l'avant-dernier modèle : ".$les_modeles[1];
//blabla
echo "le dernier prix : ".$les_prix[0];
?>



Tu vois le principe ?
Raf

Re: Requette sql : dernier et avant dernier

Réponse de squal

Le : 03/07/2008 à 19:49:07

nikel merci encore rafaelle,

Je teste se soir ...


Bisous,
Retour à l'index du forum


Ajouter une réponse

Nom :

Email :

Titre :

Message :

Combien font 3 + 2 ?

Mise en forme : gras = [b]...[/b], italic = [i]...[/i], souligné = [u]...[/u], citation = [quote]...[/quote], lien = [url]liens_externe[/url] ou [url nom=texte]liens_externe[/url], code source : [code]...[/code]

Recevoir les réponses par mail :
Oui Non

Mémoriser mon nom et mon email :
Oui Non

 

Charte des forums PHPDébutant

Bienvenue à vous,

Vous voici donc prêt à poster sur les forums de PHPDébutant. Avant toute chose, merci de prendre le temps de lire les quelques lignes qui suivent.

Attention, à partir du moment ou vous postez dans les forums, vous acceptez la présente charte. Si votre message est modéré ou supprimé, vous ne pourrez pas dire que vous n'étiez pas au courant des règles !

Pourquoi une charte

Le but de cette charte est simple : que ces forums restent cordiaux et que les personnes aidant les autres ne se sentent pas lésées, insultées, critiquées. Pour que ces forums fonctionnent, il faut des personnes qui répondent aux questions. Pour que celles ci restent sur le forum, il faut les traiter avec respect, et ne pas les confondre avec des bonnes poires, esclaves, etc...

Mesures de régulation

  • Un nouveau message ne disant pas bonjour, ou insultant, dont le titre est tout en majuscules, pourra être supprimé sans justification (raisons non limitatives).
  • Prenez le temps de vérifier que la question que vous allez poser n'a pas déjà été posée, à l'aide du formulaire de recherche.
  • Prenez également le temps de vérifier que la réponse à votre question ne se trouve pas dans les tutoriaux. Nous ne pouvons pas répeter pour chaque visiteur tous les cours, il sont écrits, profitez-en (dans l'ordre tant qu'à faire) !
  • Nous ne faisons pas de scripts tout prêts. Nous aidons et vous guidons pour que vous puissiez trouver vous même la réponse, ce qui est beaucoup plus formateur.
  • Si vous comptez poster un message publicitaire, abstenez-vous. Au mieux le message sera supprimé, au pire les habitués descendront votre service en flamme.
  • Pour tout message de recrutement, précisez bien votre demande. Inutile de poster pour trouver un développeur pour faire gratuitement votre site de webmastering qui vous rapportera plein de sous. Les seuls coups de mains donnés en développement sont pour des associations ou des sujets passionnant un développeur.
  • Toute personne tenant des propos racistes ou illicites sera bannie et pourra faire l'objet de poursuites.
  • L'humour étant très présent sur ces forums, ne réagissez pas violemment à des propos qui pourraient être à prendre au second degré et avec de l'humour.
  • Attention aux trolls ! Leur multiplication peut entraîner la mort des forums, et sans forum, plus d'aide !
  • Respectez les thèmes des forums. Pensez aussi à vérifier que votre message n'a pas été déplacé si vous le croyez effacé.

Conseils

  • N'oubliez pas que les personnes à qui vous vous adressez sont des bénévoles qui donnent de leur temps pour vous. Si vous êtes méchants avec eux, il n'aideront plus et vous n'aurez plus d'aide !
  • Ne soyez pas pressé. Nous avons une vie aussi, et nous ne sommes par forcément tout le temps disponibles.
  • N'oubliez pas que les smileys sont la pour faire comprendre l'humeur dans laquelle vous rédigez un message. Il est indispensable de mettre des smileys quand vous faites de l'humour, sinon le message pourrait être mal perçu (ca serait quand même idiot de plomber l'ambiance en faisant de l'humour !).
  • Surveillez votre orthographe, nous ne vous demandons pas d'être littéraire, mais que votre message soit au moins compréhensible. Evitez à tout prix le style SMS.
  • Expliquez clairement le problème, ce n'est pas toujours facile, mais mieux vaut essayer de le faire le plus possible.
  • Ne postez pas de questions trop vagues du genre "comment faire un forum". Cela ne sert à rien, cela ne s'explique pas sur un coin de forum.
  • Mettez un titre clair, correspondant au sujet que vous allez poster. A l'aide, au secours, etc... ne sont pas d'une grande utilité pour ceux qui vont vous aider. Parfois nous passons en coup de vent, et si nous ne savons pas ce que va contenir le message, nous ne le regarderons même pas.
  • Ne mettez par [URGENT] ou autre joyeuseté du genre dans vos titres de messages. Cela irrite les gens (il y'a plus urgent dans la vie, pensez aux gens qui meurent de faim ou ayant besoin des pompiers, ça c'est urgent), et vous n'aurez pas votre réponse plus vite pour autant.
  • Si vous connaissez déjà à quel domaine votre question d'adresse (par exemple mysql, html, php, javascript), n'hésitez pas à le marquer au début de votre message, avec un [html] par exemple (notez les minuscules).
  • Ne dites pas "ça marche pas". Il y a toujours des raisons. Je vous invite à consulter le tutorial "ça marche pas" qui vous aidera à mieux expliquer votre problème.
  • Ne postez pas 36000 lignes de code. Sur le forum, le code apparaît non coloré et sans indentation, ce qui est illisible. Au dessus de 5 lignes, plus personne ne lit et vous n'aurez pas de réponse. Utilisez le wall
  • En règle générale restez courtois et clair, n'oubliez pas que la politesse fait partie de la vie courante. Il est de bon ton de dire bonjour même pour une réponse, même plusieurs fois dans la journée (ceux qui vous lisent n'ont pas forcément lu vos autres messsages)

La Fin

Avec tout ces conseils vous augmenterez les chances de réponse, leur pertinence et leur rapidité

Voilà, ça sera tout, bonne écriture :)

Fermer les règles et poster un message


www.phpdebutant.org © 2008 - L'équipe de phpDebutant - Hébergement : WDMédia-hébergement