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

Windows Forms Discussion :

[C#] Ajout d'une ligne dans un dataset


Sujet :

Windows Forms

  1. #1
    Membre éclairé
    Avatar de frechy
    Inscrit en
    Novembre 2004
    Messages
    343
    Détails du profil
    Informations personnelles :
    Âge : 41

    Informations forums :
    Inscription : Novembre 2004
    Messages : 343
    Par défaut [C#] Ajout d'une ligne dans un dataset
    Voici mon problème:

    J'ai 2 forms
    Form1:

    Form2:


    Dans la 1ere j'ai un Datagrid qui est rempli à l'aide d'un dataset(celui-ci contient les données d'une requette sql que j'ai réalisée tout au début)

    En dessous du DataGrid un bouton Ajouter, celui-ci renvoi vers ma 2eme form qui s'occupe d'enregistrer les données nécessaire à l'ajout d'une ligne.

    Le but est donc d'ajouter les données obtenue de la 2eme form dans le dataset qui se trouve sur la 1ere form.

    *Mon premier problème, je ne sais pas si je dois envoyer la var DataSet créée dans la form1 à la form2...et comment?
    Car dans la form1 je fais form2.ShowDialog(); je ne vai quand meme pas passer la dataset en paramettre dans ShowDialog()...
    Le + simple je pense serais que la form2 renvois l'objet que j'ai créé dans la form2....qui je rapelle correspond à une ligne...et là encore je ne vois pas comment je pourais renvoyer un objet puisque j'apelle la methode ShowDialog()...

    *Mon 2eme prob: je n'arrive pas à rajouter une ligne dans un dataset... j'ai essayé de faire un truc du genre:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    objetDataSet.Tables("Nomdelatable").NewRow(ObjetCréé);
    Voilà j'espere que j'ai été assez clair et que vous avez comppris ce que j'essaye de faire...

    Merci pour vos futures réponses...

  2. #2
    Membre éprouvé
    Profil pro
    Inscrit en
    Décembre 2004
    Messages
    92
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2004
    Messages : 92
    Par défaut
    Bonjour,
    pour la première partie de ta question, tu as deux solutions.
    Soit tu crée un constructeur de form2 avec un DataSet en paramètre. Tu récupères ensuite celui-ci par une propriété de la form2 depuis la form1 après ton showDialog.
    Soit tu crée une propriété publique sur ta première form et travaille directement dessus à partir de form2.
    Perso je préfère la première solution car form2 n'interfère pas avec les objets de form1. En d'autres termes chacun fait ce qu'il a à faire même si c'est un peu plus gourmand...

  3. #3
    Membre éprouvé
    Profil pro
    Inscrit en
    Décembre 2004
    Messages
    92
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2004
    Messages : 92
    Par défaut
    Pour la deuxième partie, il n'y a pas un truc du genre acceptChanges dans la table du dataset? Il me semble que ca vient de là mais je n'y mets pas ma main à couper ...

  4. #4
    Membre averti
    Profil pro
    Inscrit en
    Octobre 2004
    Messages
    58
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2004
    Messages : 58
    Par défaut
    Pour la 2ème question, j'en mettrai pas ma main à couper non plus mais...

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    dim row as datarow
    row = objetDataset.Tables("Nomdelatable").newRow
     
    'Traitement sur row...
     
    objetDataset.Tables("Nomdelatable").Rows.Add(row)
    Après, j'ai pas eu le temps de tester alors c'est paut être pas terrible...

  5. #5
    Membre confirmé
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    80
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2004
    Messages : 80
    Par défaut
    Salut !

    Pour ta première question , les solutions de ld9474 sont bonnes et je t'en propose une troisième si tu ne veux passer par les constructeurs.
    C'est d'écrire une méthode publique écrit comme suit: (En
    meme temps dans le code suivant je réponds a ta deuxième question)


    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
     
    public void ShowForm2 (DataSet ds) 
    {
    DataRow dr;
     
    this.ShowDialog ();
     
    dr = objetDataSet.Tables("Nomdelatable").NewRow ();
     
    dr ["IdOpReal"] = txtBoxCodeOperation.Text   //tu récuperes la valeur rentrée dans le text Box Code operation
    //ici tu fais pareil pour les auitres
     
    //et enfin tu dois rajouter ta nouvelle row a la table de la dataset comme ceci
    objetDataSet.Tables("Nomdelatable").Rows.Add (dr);
     
    }
    Et voila ca devrait etre bon maintenant !

  6. #6
    Membre confirmé
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    80
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2004
    Messages : 80
    Par défaut
    J'ai oublié de préciser que dans ta Form1 tu n'appelles plus fprm2.ShowDialog () mais plutot form2.ShowForm2 (taDataSet), mais je pense que tu l'avais déjà compris !

  7. #7
    Membre éclairé
    Avatar de frechy
    Inscrit en
    Novembre 2004
    Messages
    343
    Détails du profil
    Informations personnelles :
    Âge : 41

    Informations forums :
    Inscription : Novembre 2004
    Messages : 343
    Par défaut
    Merci pour vos réponses, c etait bon sauf que ce n'est pas

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    dr = objetDataSet.Tables("Nomdelatable").NewRow ();
    Mais
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    dr = objetDataSet.Tables["Nomdelatable"].NewRow ();
    Sinon en se qui concerne la question1... j'ai finalement déclarer une var public static dans form2 que je peux accéder à partir du form1.

    Et je voudrais savoir: on ne peut pas déclarer des méthodes public dans une form? enfin si mais je n'arrive pas à y accéder à partir d'une autre form, il me dit que la fonction n'est pas déclarée...enfin je supose que c est pcque c est une form...

  8. #8
    Rédacteur
    Avatar de Thomas Lebrun
    Profil pro
    Inscrit en
    Octobre 2002
    Messages
    9 161
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : France

    Informations forums :
    Inscription : Octobre 2002
    Messages : 9 161
    Par défaut
    Citation Envoyé par frechy
    Et je voudrais savoir: on ne peut pas déclarer des méthodes public dans une form? enfin si mais je n'arrive pas à y accéder à partir d'une autre form, il me dit que la fonction n'est pas déclarée...enfin je supose que c est pcque c est une form...
    Met les en public et static

  9. #9
    Membre éclairé
    Avatar de frechy
    Inscrit en
    Novembre 2004
    Messages
    343
    Détails du profil
    Informations personnelles :
    Âge : 41

    Informations forums :
    Inscription : Novembre 2004
    Messages : 343
    Par défaut
    Oui c est ce que j'ai du faire, mais je ne compprend pas pourquoi on est obligé de déclarer ses fonction public static lorsqu'on est dans une form...alors que dans une class cormale public suffit

  10. #10
    Membre confirmé
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    80
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2004
    Messages : 80
    Par défaut
    Merci pour vos réponses, c etait bon sauf que ce n'est pas

    Code:

    dr = objetDataSet.Tables("Nomdelatable").NewRow ();


    Mais
    Code:

    dr = objetDataSet.Tables["Nomdelatable"].NewRow ();
    En effet !

    Pour ta question une méthode publique ,que ca soit pour une form ou pour une classe,n'est accessible que lorsque la classe est instanciée.Si tu la mets en static, elle est tout le temps accessible que ca soit une form ou une classe.En code ca donne ca:


    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
     
    public class Maclasse {
     
      public static void MaMethodeStatic () {
         //bla bla
      }
     
      public void MaMethodePublique () {
         //blabla
      }
    }
     
    ///Dans une autre classe on accede aux methodes de Maclasse de la facon suivante
    public class UneAutreClasse {
     
        public void UneMethodeQuelconque () {
     
      //si je veux appeler la méthode static de Maclasse je fais comme ceci
           MaClasse.MaMethodeStatic ();   
     
        } 
     
         public void UneAutreMethodeQuelconque () {
     
          //si je veux appeler la methode publique de Maclasse je fais comme ceci
           Maclasse myclass = new Maclasse ();
           myClass.MaMethodePublique ();
     
         }
     
    }

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

Discussions similaires

  1. ajout d'une ligne dans un fichier
    Par anibal dans le forum Langage
    Réponses: 2
    Dernier message: 15/03/2007, 11h31
  2. Réponses: 2
    Dernier message: 08/03/2007, 11h06
  3. [VBA-E] ajout d'une ligne dans 2 feuilles
    Par PHPdudimanche dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 14/12/2006, 10h10
  4. Détecter l'ajout d'une ligne dans une table
    Par louis_figos dans le forum Access
    Réponses: 2
    Dernier message: 07/12/2006, 17h31
  5. [C#] Problème d'ajout d'une ligne dans une DataTable
    Par therock dans le forum Windows Forms
    Réponses: 3
    Dernier message: 09/11/2006, 08h27

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