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 :

Test si la valeur d'un champ est au maximum [MySQL]


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    Technicien informatique
    Inscrit en
    Mai 2011
    Messages
    105
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : Technicien informatique
    Secteur : Industrie Pharmaceutique

    Informations forums :
    Inscription : Mai 2011
    Messages : 105
    Par défaut Test si la valeur d'un champ est au maximum
    Bonjour,

    cela fait un moment que cherche récupérer la valeur maximun d'un champ dans un table mysql et ensuite faire un test

    ex:

    Si champ 'points' = à la valeur maximum de 'points' alors appliquer la class

    voici mon code. J'essaie de faire ce test à la ligne 80 de mon 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
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    <?php
    include 'connexion.php';
     
    // Le nom de notre table
    $tablename = 'mysql_licence_joueur';
     
    // Tri sur colonne
    $tri_autorises = array('id','joueur','equipe','assiste','buts','points','penalites','points','nbre_match');
    $order_by = in_array($_GET['order'],$tri_autorises) ? $_GET['order'] : 'joueur';
     
     
    // Sens du tri
    $order_dir = isset($_GET['inverse']) ? 'DESC' : 'ASC';
    $filtre = $_GET['nom_equipe'];
     
    $var=0; 
     
    // Préparation de la requête
     
     
     
     
     
    $sql =('SELECT * FROM '.$tablename.' where equipe ="'.$_GET["nom_equipe"].'" and nbre_match <> 0
    ORDER BY '.$order_by.' '.$order_dir.'');
     
    $result = mysql_query($sql);
     
     
    // Notre fonction qui affiche les liens
    function sort_link($text, $order=false)
    {
        global $order_by, $order_dir;
     
        if(!$order)
            $order = $text;
     
        $link = '<a href="index.php?option=com_content&view=article&id=23&nom_equipe='.$_GET["nom_equipe"].'&order=' . $order;
        if($order_by==$order && $order_dir=='ASC')
            $link .= '&inverse=true';
        $link .= '"';
        if($order_by==$order && $order_dir=='ASC')
            $link .= ' class="order_asc"';
        elseif($order_by==$order && $order_dir=='DESC')
            $link .= ' class="order_desc"';
        $link .= '>' . $text . '</a>';
     
        return $link;
    }
     
     
    // Affichage
    ?>
    <div id="texte_haut_article" class="titre_article">
    <?php echo $_GET["nom_equipe"]?>
    </div>
    <table width="690" bgcolor="<?php echo $bgc;?>" cellspacing="0" align="left" class="semi-transparent-calendrier">
            <tr>
            <td width="10"class="info"></th>
            <td width="18"class="info"></th>
            <th width="200" class="info">Joueurs <?php echo sort_link('<img src="img/asc.png" border="0" title="Tri croissant">', 'joueur') ?> <a href="index.php?option=com_content&view=article&id=23&nom_equipe=<?php echo $_GET["nom_equipe"]?>&order=joueur&inverse=true"><img src="img/desc.png" title="Tri décroissant"/></th>
     
            <th width="110" class="info">Assistes <?php echo sort_link('<img src="../img/asc.png" border="0" title="Tri croissant">', 'assiste') ?> <a href="index.php?option=com_content&view=article&id=23&nom_equipe=<?php echo $_GET["nom_equipe"]?>&order=assiste&inverse=true"><img src="img/desc.png" title="Tri décroissant"/></th>
     
            <th width="90" class="info">Buts <?php echo sort_link('<img src="img/asc.png" border="0" title="Tri croissant">', 'buts') ?> <a href="index.php?option=com_content&view=article&id=23&nom_equipe=<?php echo $_GET["nom_equipe"]?>&order=buts&inverse=true"><img src="img/desc.png" title="Tri décroissant"/></th>
     
            <th width="90" class="info">Pts <?php echo sort_link('<img src="img/asc.png" border="0" title="Tri croissant">', 'points') ?> <a href="index.php?option=com_content&view=article&id=23&nom_equipe=<?php echo $_GET["nom_equipe"]?>&order=points&inverse=true"><img src="img/desc.png" title="Tri décroissant"/></th>
     
            <th width="110" class="info">Penalités <?php echo sort_link('<img src="img/asc.png" border="0" title="Tri croissant">', 'penalites') ?> <a href="index.php?option=com_content&view=article&id=23&nom_equipe=<?php echo $_GET["nom_equipe"]?>&order=penalites&inverse=true"><img src="img/desc.png" title="Tri décroissant"/></th>
     
            <th width="90" class="info">*Nbm <?php echo sort_link('<img src="img/asc.png" border="0" title="Tri croissant">', 'nbre_match') ?> <a href="index.php?option=com_content&view=article&id=23&nom_equipe=<?php echo $_GET["nom_equipe"]?>&order=nbre_match&inverse=true"><img src="img/desc.png" title="Tri décroissant"/></th>
        </tr>
     
    <?php 
     
     
    while( $row=mysql_fetch_assoc($result) )
    {
            $nb_classement++;//commence à compter depuis 1
    if ($row['points']== valeur maximum du champ points) 
    { 
    echo '<tr class="degrader">';
     
    }else
     
    if ($var==0) 
    { 
    echo '<tr bgcolor="#333333">';
    $var=1; 
    }else{ 
    echo '<tr bgcolor="#666666">';
    $var=0; 
    } 
     
        echo '<td></td>';
        echo '<td>'.$nb_classement.'.</td>';
        echo '<td><a href="index.php?option=com_content&view=article&id=75&id_joueur='.$row['id_joueur'].'" title="Voir les détails"/a>'.$row['joueur'].'</a></td>';
     
        echo '<td>'.$row['assiste'].'</td>';
        echo '<td>'.$row['buts'].'</td>';
        echo '<td>'.$row['points'].'</td>';
        echo '<td>'.$row['penalites'].'</td>';
        echo '<td>'.$row['nbre_match'].'</td>';
     
        }
        echo '</tr>'."\n";
     
     
    echo '</table>'."\n"; 
    echo '<div id="bas_page_statistiques">';
    echo '*Nbm=(Nombre de matchs joué)';
    echo '</div>';
     
    ?>
    Merci pour votre aide

  2. #2
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Par défaut
    Tu aurais pu nous faciliter un peu la lecture du code, ta requête est à la ligne 27, le fetch ligne 77, et le point qui concerne ta question à la ligne 80.

    Bref tu peux simplement faire une requête MAX en plus.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  3. #3
    Membre confirmé
    Homme Profil pro
    Technicien informatique
    Inscrit en
    Mai 2011
    Messages
    105
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : Technicien informatique
    Secteur : Industrie Pharmaceutique

    Informations forums :
    Inscription : Mai 2011
    Messages : 105
    Par défaut
    merci,

    c'est vrai pour la lecture. Y a juste que j'ai tj ajouté plus sans faire l'ordre

    Par contre pour la requête MAX j'ai déjà essayé plein de chose mais ça ne fonctionne pas et je ne sais pas ou la placer.

  4. #4
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Par défaut
    Ca j'ai bien vu que tu avais du mal à placer les éléments dans ton code

    Tu peux la mettre n'importe ou tant que c'est avant d'en avoir besoin.

    La logique c'est
    requête max
    requête complète
    boucle fetch
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  5. #5
    Membre confirmé
    Homme Profil pro
    Technicien informatique
    Inscrit en
    Mai 2011
    Messages
    105
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : Technicien informatique
    Secteur : Industrie Pharmaceutique

    Informations forums :
    Inscription : Mai 2011
    Messages : 105
    Par défaut
    voila j'ai fais cette requête max en début de code mais je n'arrive à récuper ces valeurs

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    $rs = mysql_query('SELECT equipe, MAX(points) AS points FROM mysql_licence_joueur GROUP BY equipe');
    $myrow = mysql_fetch_array($rs);

  6. #6
    Expert confirmé

    Homme Profil pro
    Développeur Web
    Inscrit en
    Septembre 2010
    Messages
    5 418
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Septembre 2010
    Messages : 5 418
    Par défaut
    Pour afficher le contenu d'un tableau on peut utiliser print_r. Pour bien visualiser ton retour durant la phase de développement tu peux donc faire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    //...
    $myrow = mysql_fetch_array($rs);
    echo '<pre>';
    print_r($myrow);
    echo '</pre>';

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 5
    Dernier message: 09/12/2007, 16h20
  2. Réponses: 7
    Dernier message: 27/06/2006, 20h43
  3. test sur la valeur d'un champ
    Par Atchoum_002 dans le forum Langage
    Réponses: 2
    Dernier message: 27/06/2006, 16h16
  4. Réponses: 8
    Dernier message: 08/02/2006, 09h13
  5. [SQL] ligne dont la valeur d'un champ est unique
    Par kopofb dans le forum Langage SQL
    Réponses: 2
    Dernier message: 10/11/2005, 20h53

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