IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

PHP & Base de données Discussion :

Erreur dans ma pagination (alias requis)


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre expérimenté
    Avatar de beegees
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mars 2004
    Messages
    3 610
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Enseignement

    Informations forums :
    Inscription : Mars 2004
    Messages : 3 610
    Par défaut Erreur dans ma pagination (alias requis)
    Bonjour tout le monde

    J'essaie de faire une pagination pour mon site.

    J'utilise ce code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    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
     
    <?php
    //Je sélectionne le matricule, nom et prénom de l'étudiant qui sont dans dans le requete apres le premier IN
    /*$Selection_etudiants = " SELECT DISTINCT etudiants.MATRICULE_ET, etudiants.nom_et, etudiants.prenom_et
    FROM etudiants
    WHERE etudiants.matricule_et
    IN (
    
    SELECT DISTINCT MATRICULE_ET
    FROM inscrits_en
    WHERE MNEMONIC
    IN (
    
    SELECT MNEMONIC
    FROM cours
    WHERE NOM_ANNEE = 'BA3'
    AND TYPE_DE_COURS = 'TH'
    AND CATEGORIE = 'NORMAL'
    )
    )";
    */
     
     
    $Selection_etudiants = " SELECT DISTINCT a.MATRICULE_ET 
    FROM inscrits_en AS a 
    WHERE MNEMONIC 
    IN (  
    SELECT MNEMONIC 
    FROM cours AS b 
    WHERE b.NOM_ANNEE = 'BA3' 
    AND b.TYPE_DE_COURS = 'TH' 
    AND b.CATEGORIE = 'NORMAL' 
    )"; 
     
    //$req_Selection_etudiants = mysql_query($Selection_etudiants);
     
     
     
    //echo $Selection_etudiants;
     
    // On met dans une variable le nombre de messages qu'on veut par page
    $nombreDeMessagesParPage = 1;
    // On récupere le nombre total d'étudiants
    $retour = mysql_query('SELECT COUNT(*) AS nb_etudiants FROM ('. $Selection_etudiants.')') or die(mysql_error());
    echo 'ici';
    $donnees = mysql_fetch_array($retour);
    $totalDesMessages = $donnees['nb_etudiants'];
    // On calcule le nombre de pages a créer
    $nombreDePages  = ceil($totalDesMessages / $nombreDeMessagesParPage);
    // Puis on fait une boucle pour écrire les liens vers chacune des pages
    echo 'Page : ';
    for ($i = 1 ; $i <= $nombreDePages ; $i++)
    {
        echo '<a href="livreor.php?page=' . $i . '">' . $i . '</a> ';
    }
     
     
    ?>
     
    </p></p>
    Mais j'obtiens à chaque fois ce message d'erreur :

    Every derived table must have its own alias
    Sauriez-vous me dire comment je peux faire pour réparer cela ?

    Merci d'avance.

    beegees

  2. #2
    Modérateur

    Avatar de MaitrePylos
    Homme Profil pro
    DBA
    Inscrit en
    Juin 2005
    Messages
    5 506
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : Belgique

    Informations professionnelles :
    Activité : DBA
    Secteur : Service public

    Informations forums :
    Inscription : Juin 2005
    Messages : 5 506
    Par défaut
    Bonjour, il manque l'alias devant MNEMONIC

    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    SELECT DISTINCT a.MATRICULE_ET 
    	FROM inscrits_en AS a 
    WHERE a.MNEMONIC IN (
    		SELECT MNEMONIC 
    			FROM cours AS b 
    		WHERE b.NOM_ANNEE = 'BA3' 
    		AND b.TYPE_DE_COURS = 'TH' 
    		AND b.CATEGORIE = 'NORMAL' 
    )

  3. #3
    Membre expérimenté
    Avatar de beegees
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mars 2004
    Messages
    3 610
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Enseignement

    Informations forums :
    Inscription : Mars 2004
    Messages : 3 610
    Par défaut
    Bonjour MaîtrePylos,

    Merci pour ta réponse.

    Avec ce code :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    $Selection_etudiants = " SELECT DISTINCT a.MATRICULE_ET 
    	FROM inscrits_en AS a 
    WHERE a.MNEMONIC IN (
    		SELECT MNEMONIC 
    			FROM cours AS b 
    		WHERE b.NOM_ANNEE = 'BA3' 
    		AND b.TYPE_DE_COURS = 'TH' 
    		AND b.CATEGORIE = 'NORMAL' 
    )
    "; 
     
    //$req_Selection_etudiants = mysql_query($Selection_etudiants);
     
     
     
    //echo $Selection_etudiants;
     
    // On met dans une variable le nombre de messages qu'on veut par page
    $nombreDeMessagesParPage = 1;
    // On récupere le nombre total d'étudiants
    $retour = mysql_query('SELECT COUNT(*) AS nb_etudiants FROM ('. $Selection_etudiants.')') or die(mysql_error());
    le problème persiste

    Qu'en penses-tu ?

    Encore merci.

    beegees

  4. #4
    Modérateur

    Avatar de MaitrePylos
    Homme Profil pro
    DBA
    Inscrit en
    Juin 2005
    Messages
    5 506
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : Belgique

    Informations professionnelles :
    Activité : DBA
    Secteur : Service public

    Informations forums :
    Inscription : Juin 2005
    Messages : 5 506
    Par défaut
    Idem dans le IN

    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
     SELECT DISTINCT a.MATRICULE_ET 
    	FROM inscrits_en AS a 
    WHERE a.MNEMONIC IN (
    		SELECT b.MNEMONIC 
    			FROM cours AS b 
    		WHERE b.NOM_ANNEE = 'BA3' 
    		AND b.TYPE_DE_COURS = 'TH' 
    		AND b.CATEGORIE = 'NORMAL' 
    )

Discussions similaires

  1. [Tomcat] configuration d'une page d'erreur dans web.xml
    Par Super Castor dans le forum Tomcat et TomEE
    Réponses: 3
    Dernier message: 08/04/2009, 15h58
  2. [Thread] Erreur dans une classe interne
    Par totof2308 dans le forum Général Java
    Réponses: 5
    Dernier message: 03/06/2004, 08h15
  3. [Lien]erreur dans mon programme python
    Par durnambule dans le forum Général Python
    Réponses: 11
    Dernier message: 29/01/2004, 14h59
  4. [Erreur dans la lib...]
    Par Gonath dans le forum OpenGL
    Réponses: 3
    Dernier message: 22/12/2003, 09h02
  5. Erreur dans l'utilisation de SWAP
    Par mire dans le forum Langage
    Réponses: 12
    Dernier message: 15/03/2003, 21h39

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo