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 :

Problème différenciation entre valeur null et zéro [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Membre actif
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    526
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 526
    Points : 224
    Points
    224
    Par défaut Problème différenciation entre valeur null et zéro
    Bonjour ,

    J'ai une table note definie de cette manière :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    CREATE TABLE note
    (
    IdEtudiant VARCHAR(20) NOT NULL,
    NomModule VARCHAR(20) NOT NULL,
    NomFormation VARCHAR(20) NOT NULL,
    DateFormation INT NOT NULL,
    NumSemestre VARCHAR(5) NOT NULL,
    PRIMARY KEY(IdEtudiant,NomModule,NomFormation,DateFormation,NumSemestre),
    FOREIGN KEY (IdEtudiant) REFERENCES etudiant(IdEtudiant),
    FOREIGN KEY (NomModule,NomFormation,DateFormation,NumSemestre) REFERENCES modules(NomModule,NomFormation,DateFormation,NumSemestre),
    NoteExam float NOT NULL,
    NoteTp float NOT NULL,
    moy float NOT NULL 
    );
    Ce que je fait avec mon programme, c'est que je veux calculer la moy du module.
    Ma formule est moy=(1/3) *NoteTp+(2/3)*NoteExam.
    Sachant que je ne suis pas obligé de rentrer une note de tp, je fais la distinction en différents cas.
    Mon pb est que mon programme n'arrive pas à faire la distinction entre un champ vide et une note égale à zéro.
    Si qq sait comment contourner le pb, merci.
    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
     
    $noteExam=parseInt($_POST['NOTEEXAMEN']);
    $noteTP=parseInt($_POST['NOTETP']);
     
    //Calcul de la moyenne du module
    if ($noteExam==0 && $noteTP==0)
    {
    $moyennne=0;
    }
     
    elseif (empty($noteTP))
    {
    	$moyennne=$noteExam;
    }
     
    elseif ($noteTP==0)                         //Pb à ce niveau là 
    {
    $moyennne=(2/3)*$noteExam;
    }
     
    elseif ($noteExam==0)
    {
    $moyennne=(1/3)*$noteTP;
    }
     
    else
    {
    	$moyennne=(2/3)*$noteExam+(1/3)*$noteTP;
    }

  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
    Points : 44 155
    Points
    44 155
    Par défaut
    Si tu dois tester un vrai zéro :
    Par contre très logiquement il faut que ce test soit avant le test empty()

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

Discussions similaires

  1. [MySQL] Problème différenciation entre valeur null et zéro
    Par stefsas dans le forum PHP & Base de données
    Réponses: 7
    Dernier message: 09/03/2010, 19h00
  2. [Toplink] Problème setParameter avec valeur null
    Par igloof dans le forum Persistance des données
    Réponses: 0
    Dernier message: 31/03/2009, 17h48
  3. Convertir une valeur Null en zéro
    Par belecom dans le forum Requêtes et SQL.
    Réponses: 2
    Dernier message: 08/05/2008, 15h37
  4. Remplacer une valeur <null> par zéro
    Par diablotin dans le forum SQL
    Réponses: 2
    Dernier message: 28/08/2007, 21h07
  5. Problème requette avec valeur NULL
    Par Destiny dans le forum Langage SQL
    Réponses: 3
    Dernier message: 21/05/2007, 08h35

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