Partage
  • Partager sur Facebook
  • Partager sur Twitter

bonsoir je code en c# j'ai une erreure

L'exception System.NullReferenceException n'a pas été gérée

    15 février 2021 à 19:16:20

    je code en poo  et je n'arrive pas a résoudre ce problème depuis hier.en fait j'ai trois classe donc  ADHERENT,OPERATION,PARTICIPANT.les cles primaire d'adherent et operation migre vers participant.

    voici la classe participantDAO qui contient les requetes l'erreur signale au niveau de participant.adherent.id

    class ParticipantDAO

        {

            public static void save(Participant participant)

            { // s'occupe de la l'ajout et de la modification

                if (participant.id == 0)

                {

                    OdbcCommand cmd = new OdbcCommand("insert into participant(idad,idop,datep) values(?,?,?)", BDD.getconnection());

                    cmd.Parameters.Add("@z", OdbcType.Int).Value = participant.adherent.id;

                    cmd.Parameters.Add("@e", OdbcType.Int).Value = participant.operation.id;

                    cmd.Parameters.Add("@t", OdbcType.Date).Value = participant.datep.ToShortDateString();

                    cmd.ExecuteNonQuery();

                    cmd.Dispose();

                }

    voici la methode qui me permet de recuperer les donner saisir dans le textbox et combobox puis met dans les objets

      public void Form2Participant()

            {

                Participant participant = new Participant();

                participant.id = int.Parse(labelid.Text);

                participant.adherent = AdherentDAO.find2(cbadherent.Text);

                participant.operation = OperationDAO.find2(cboperation.Text);

                participant.datep = txtdatep.Value;

            }

    ensuite la methode find2

    public static Adherent find2(string nom)//recherche parport au nom de l'adherent

            {

               Adherent adherent = null;

                OdbcCommand cmd = new OdbcCommand("select * from adherent where nom = ? ", BDD.getconnection());

                cmd.Parameters.Add("@id", OdbcType.Text).Value = nom;

                OdbcDataReader dr = cmd.ExecuteReader();

                if (dr.Read())

                {

                    adherent = new Adherent() { id = dr.GetInt32(0), nom = dr.GetString(1), prenom = dr.GetString(2), datenaiss = dr.GetString(3), lieunaiss = dr.GetString(4), sexe = dr.GetString(5), numcni = dr.GetInt32(6), tel = dr.GetString(7) };

                }

                dr.Close();

                dr = null;

                cmd.Dispose();

                return adherent;  

            }

    merci de bien vouloir m'aider

    • Partager sur Facebook
    • Partager sur Twitter
      15 février 2021 à 20:01:08

      Bonjour,

      Le message qui suit est une réponse automatique activée par un membre de l'équipe. Les réponses automatiques leur permettent d'éviter d'avoir à répéter de nombreuses fois la même chose, ce qui leur fait gagner du temps et leur permet de s'occuper des sujets qui méritent plus d'attention.
      Nous sommes néanmoins ouverts et si vous avez une question ou une remarque, n'hésitez pas à contacter la personne en question par Message Privé.

      Pour plus d'informations, nous vous invitons à lire les règles générales du forum

      Merci de colorer votre code à l'aide du bouton Code

      Les forums d'Openclassrooms disposent d'une fonctionnalité permettant de colorer et mettre en forme les codes source afin de les rendre plus lisibles et faciles à manipuler par les intervenants. Pour cela, il faut utiliser le bouton Code de l'éditeur, choisir un des langages proposés et coller votre code dans la zone prévue. Si vous utilisez l'éditeur de messages en mode Markdown, il faut utiliser les balises <pre class="brush: vb;">Votre code ici</pre>.

      Merci de modifier votre message d'origine en fonction.

      Liens conseillés

      • Partager sur Facebook
      • Partager sur Twitter
        15 février 2021 à 20:26:34

        Une raison particulière pour coder comme il y a 20 ans ?

        Sinon, les ORM, c'est plus une nouveauté depuis bien longtemps.

        Pourquoi "participant.adherent" ne peut-il pas être null ?

        Le débogueur est ton ami.

        • Partager sur Facebook
        • Partager sur Twitter
        Je recherche un CDI/CDD/mission freelance comme Architecte Logiciel/ Expert Technique sur technologies Microsoft.
          16 février 2021 à 13:13:05

          et c'est quoi le message d'erreur aussi ?
          • Partager sur Facebook
          • Partager sur Twitter

          bonsoir je code en c# j'ai une erreure

          × Après avoir cliqué sur "Répondre" vous serez invité à vous connecter pour que votre message soit publié.
          × Attention, ce sujet est très ancien. Le déterrer n'est pas forcément approprié. Nous te conseillons de créer un nouveau sujet pour poser ta question.
          • Editeur
          • Markdown