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

Bases de données Delphi Discussion :

Type de données


Sujet :

Bases de données Delphi

  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    108
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 108
    Par défaut Type de données
    Bonjour

    voila mon problème
    j'ai une table dans laquelle je rentre des notes donc dans access j'ai spécifié pour les champs : numérique ==> réel double.

    il se peut qu'un éleves soit absent pour une épreuve du brevet, donc je veut maqué dans la case de l'éleve "abs"

    et bien sur quand je veut enregistrer ==> problème "abs n'est pas un numérique"
    c'est normal.

    bref je ne peut pas l'aisser a cet éleves un 0 ca le pénaliseré.

    comment je peut faire ??

    merci d'avance.

  2. #2
    Expert confirmé
    Avatar de Cl@udius
    Homme Profil pro
    Développeur Web
    Inscrit en
    Février 2006
    Messages
    4 878
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Février 2006
    Messages : 4 878
    Par défaut
    Salut

    Je voies 2 solutions pour gérer les abscences des élèves.

    1° Cas:
    Tu n'entres pas sa note !! (La solution la plus bête ! )

    2° Cas:
    Tu entres par exemple une note négative (ex: -1). -1 précisant que l'élève était absent à l'épreuve.
    Et lors de tes calculs de moyenne tu ne tiens compte uniquement des notes positives ou nulles.

    Voilà pour une première approche.

    @+ Claudius

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    108
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 108
    Par défaut
    Je pensse que je vais utiliser la 2 éme solution car si on ne met pas de note et bien la aussi on obtien une erreur comme quoi "" n'est pas un caractère valable.

  4. #4
    Expert confirmé
    Avatar de Cl@udius
    Homme Profil pro
    Développeur Web
    Inscrit en
    Février 2006
    Messages
    4 878
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Février 2006
    Messages : 4 878
    Par défaut
    Re,

    Quand je disais que tu n'entres pas sa note, je voulais simplement dire que tu ne créais pas d'enregistrement pour cet élève.

    @+

  5. #5
    Modérateur
    Avatar de Rayek
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2005
    Messages
    5 236
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 236
    Par défaut
    Citation Envoyé par Cl@udius
    Re,

    Quand je disais que tu n'entres pas sa note, je voulais simplement dire que tu ne créais pas d'enregistrement pour cet élève.

    @+
    C'est aps une bonne idée car on ne voit pas qu'il a loupé le controle.

    Je pense que rajouter un champ 'Absent : boolean' qu'on met a vrai pour dire qu'il a ete absent.
    Après pour le calcul de la moyenne, il suffit de faire une requete qui exclue dans le calcul les enregistrements avec le champ absent à vrai.
    Modérateur Delphi

    Le guide du bon forumeur :
    __________
    Rayek World : Youtube Facebook

  6. #6
    Expert confirmé
    Avatar de Cl@udius
    Homme Profil pro
    Développeur Web
    Inscrit en
    Février 2006
    Messages
    4 878
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Février 2006
    Messages : 4 878
    Par défaut
    Salut,

    Citation Envoyé par Malatar
    C'est aps une bonne idée car on ne voit pas qu'il a loupé le controle.
    D'accord avec toi, c'est pour ca que je la qualifiais de la solution la plus bête.

    Citation Envoyé par Malatar
    Je pense que rajouter un champ 'Absent : boolean' qu'on met a vrai pour dire qu'il a ete absent.
    Après pour le calcul de la moyenne, il suffit de faire une requete qui exclue dans le calcul les enregistrements avec le champ absent à vrai.
    C'est effectivement la solution que j'aurais employée. C'est d'ailleurs ce qu'il devrait faire si il peut ajouter un champ à sa table.

    @+ Claudius

  7. #7
    Membre confirmé
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    108
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 108
    Par défaut
    bon voila il y a eut un petit changement
    quand je disé que ces champs étaient des numériques quand je fesais une requête pour obtenir ces champs par defaut il me les met a 0.

    j'en ai parler au prof qui ma demandé le programme il me dit que si la valeur par defaut est 0 c'est une source d'erreur.

    donc au final ce n'est pas plus mal je dit que mes champs vont recevoir du texte et comme ca mon histoir d'absent est réglé je peut enregistrer abs dans mon champ.

    probléme casiment réglé... et la un ptit probléme

    je fait le calcul des points de mes 3 notes je l'affiche dans une colonne et aprés je fait la moyenne donc /3 et je met dans une autre colonne.

    mais quand j'ai abs dans une case je ne veut pas qu'il face de calcul je veut que ca marque dans ma colonne total et moyenne ==> abs

    mais je ces pas pourquoi il a l'aire de faire quand même le calcul et m'affiche l'erreur : abs n'est pas une valeur entiere flotante .
    il plante a ce moment mes il m'affiche quand même abs dans les 2 colonne que je souhéte mais ne continu pas les ligne suivante.

    help me pls

    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
     
    procedure TForm1.Button2Click(Sender: TObject);
    var i :integer;
    j : integer ;
    cal1,cal2,cal3,resul : double;
    begin
    For i:=1 to televe.RowCount-1 do
    begin
      for j:=5 to televe.ColCount-3 do
      begin
        if televe.Cells[j,i] = 'abs' then
      begin
      televe.Cells[9,i]:= 'abs';
      televe.Cells[11,i] := 'abs';
      end
      else
        if televe.Cells[j,i] <> 'abs' then
        begin
    cal1 := StrToFloat(televe.Cells[5,i]);
    cal2 := StrToFloat(televe.Cells[6,i]);
    cal3 := StrToFloat(televe.Cells[7,i]);
    resul := cal1+cal2+cal3;
    televe.Cells[9,i]:=  Format('%2.2f', [resul]);
    televe.Cells[11,i] := Format('%2.2f', [resul/3]);
     
    televe.Cells[5,i] := Format('%2.2f', [cal1]);
    televe.Cells[6,i] := Format('%2.2f', [cal2]);
    televe.Cells[7,i] := Format('%2.2f', [cal3]);
       end;
       end;
      end;
    end;

  8. #8
    Expert confirmé
    Avatar de Cl@udius
    Homme Profil pro
    Développeur Web
    Inscrit en
    Février 2006
    Messages
    4 878
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Février 2006
    Messages : 4 878
    Par défaut
    Les colonnes 5, 6 et 7 sont les 3 notes de tes élèves ?
    Une ou plusieurs de ces notes peut contenir 'abs' ?

    C'est ca ?

  9. #9
    Membre confirmé
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    108
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 108
    Par défaut
    oui les colonne 5 , 6 , 7 sont les notes des 3 matières

    toutes peuvent recevoir abs
    tout comme 1 seul ou 2 .

  10. #10
    Expert confirmé
    Avatar de Cl@udius
    Homme Profil pro
    Développeur Web
    Inscrit en
    Février 2006
    Messages
    4 878
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Février 2006
    Messages : 4 878
    Par défaut
    Alors essaye plutot ceci:

    J'ai utilise TryStrToFloat qui tente de convertir un string en float qui renvoie False en cas d'échec.
    Tu dois également compter le nombre de notes pour calculer la moyenne.

    Un conseil n'hésites pas à utiliser des constantes pour repérer tes colonnes.
    C'est plus simple d'utilisation et surtout pour maintenir ton code si une nouvelle colonne était insérée dans ton stringGrid.

    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
     
    procedure TForm1.Button2Click(Sender: TObject);
    var
      i :integer;
      cal1,cal2,cal3,resul: double;
      NbNotes: Integer;
    const
      COL_N1 = 5;
      COL_N2 = 6;
      COL_N3 = 7;
      COL_TOT = 9;
      COL_MOY = 11;
    begin
      with TEleve do
      begin
        for i := 1 to RowCount-1 do
        begin
          // Nombre de notes de l'élève
          NbNotes := 0; cal1 := 0; cal2 := 0; cal3 := 0;
          if TryStrToFloat(Cells[COL_N1, i], cal1) then Inc(NbNotes);
          if TryStrToFloat(Cells[COL_N2, i], cal2) then Inc(NbNotes);
          if TryStrToFloat(Cells[COL_N3, i], cal3) then Inc(NbNotes);
     
          // Si NbNotes = 0 alors élève 'absent'
          if (NbNotes = 0) then
            begin
              Cells[COL_TOT,i]:= 'abs';
              Cells[COL_MOY,i] := 'abs';
            end
          else
            begin
              resul := cal1+cal2+cal3;
              Cells[COL_TOT,i]:=  Format('%2.2f', [resul]);
              Cells[COL_MOY,i] := Format('%2.2f', [resul/NbNotes]);
            end;
        end;
      end;
    end;
    @+

  11. #11
    Membre confirmé
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    108
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 108
    Par défaut
    haaaaaa ca fait plaisir merci beaucoup de me donner des réponsses comme ca

    il ne me reste plus qu gérer les ceut qui ont la même moyenne et mon programme sera fini ^^

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

Discussions similaires

  1. interbase : types de donnés : AutoIncrement et Date ???
    Par delphien dans le forum Bases de données
    Réponses: 2
    Dernier message: 12/04/2004, 17h29
  2. Type pour données de type email avec @
    Par jeff37 dans le forum Langage SQL
    Réponses: 4
    Dernier message: 26/01/2004, 14h50
  3. Types de données interbase
    Par Clotilde dans le forum InterBase
    Réponses: 2
    Dernier message: 18/11/2003, 14h10
  4. Réponses: 2
    Dernier message: 22/09/2003, 11h23
  5. Convertir un type de donnée sous SQL Server
    Par Fleep dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 19/08/2003, 15h15

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