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

C# Discussion :

Comment appeler une methode dans une autre Form


Sujet :

C#

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre actif
    Homme Profil pro
    Inscrit en
    Mars 2011
    Messages
    48
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Mars 2011
    Messages : 48
    Par défaut Comment appeler une methode dans une autre Form
    Bonjour,
    J'écris une application qui me permet d'écrire dans une base Mysql
    j'ai une form1 qui et une form2
    la form1 est une fenetre d'identification qui me permet de me connecter a la base, une fois la connexion vérifiré j'accede a la form2
    dans la form2 j'ai des champs ou je peux ecrire des données sur la base
    mais voila mon problème j'obtiens un message d'erreur suivant quand je valide les champs

    L'exception System.InvalidOperationException n'a pas été gérée
    Message=Connection must be valid and open.
    Voici le code de la form1:

    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
    namespace WpfApplication1
    {
        /// <summary>
        /// Logique d'interaction pour MainWindow.xaml
        /// </summary>
         public partial class MainWindow : Window
        {
            MySqlConnection wConnexion = new MySqlConnection();
            public MainWindow()
            {
                InitializeComponent();
            }
     
            private void button1_Click(object sender, RoutedEventArgs e)
            {
                // Connexion à la BDD
     
                wConnexion.ConnectionString = "Database=test;Data Source=localhost;User Id="+textBox1.Text +";Password="+ passwordBox1.Password;
     
                // Tenter la connexion sinon afficher un message d’erreur
                try
                {
                    wConnexion.Open();
                }
                catch (Exception ex)
                {
                    MessageBox.Show("Impossible de se connecter au serveur!");
                    MessageBox.Show(ex.Message);
                }
     
                wConnexion.Close();
     
                Window1 myfen = new Window1();
                myfen.Show();
     
     
                this.Close();         
            }
     
     
            private void button2_Click(object sender, RoutedEventArgs e)
            {
                this.Close();
            }
     
            private void passwordBox1_PasswordChanged_1(object sender, RoutedEventArgs e)
            {
     
            }
        }
    }
    et Voici le code de la form2

    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
    namespace WpfApplication1
    {
        /// <summary>
        /// Logique d'interaction pour Window1.xaml
        /// </summary>
         public partial class Window1 : Window
        {
            MySqlConnection wConnexion = new MySqlConnection();
     
             public Window1()
            {
                InitializeComponent();
            }
            private void textBox1_TextChanged(object sender, TextChangedEventArgs e)
            {
     
            }
     
            private void button1_Click_1(object sender, RoutedEventArgs e)
            {
     
                using (wConnexion)
                {
                    // Instancier l’objet Command
                    using (MySqlCommand wCommand = wConnexion.CreateCommand())
                    {
                        // Définition de la requête
                        wCommand.CommandText = "INSERT INTO `hibis_t`(`nom` ,`prenom` ,`message`) VALUES (" + textBox1.Text + ", "+ textBox2.Text +"," + textBox3.Text + ")";
                        //wCommand.CommandText = "UPDATE INTO `hibis_t`(`nom` ,`prenom` ,`message`) VALUES (" + textBox1.Text + ", " + textBox2.Text + "," + textBox3.Text + ")";
     
     
                        // Exécution de la requête
                       // try
                        //{
                            wCommand.ExecuteNonQuery();
                        //}
                        //catch (InvalidOperationException)
                        //{
                          //  MessageBox.Show("Erreur impossible d'écrire dans la table!");
                        //}
     
                        wConnexion.Close();
                    }
                }
            }     
     
        }
    }

    comme vous pouvez le voir je suis obligé de remettre la methode MySqlConnection wConnexion = new MySqlConnection(); une deuxieme fois alors que la connexion a la base est deja active
    comment puis je utiliser la methode de la form1 dans la form2 svp?

    Merci

  2. #2
    Membre émérite
    Avatar de Gurdil le nain
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Avril 2009
    Messages
    468
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

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

    Informations forums :
    Inscription : Avril 2009
    Messages : 468
    Par défaut
    Premièrement

    Ensuite, dans ta mainWindow, tu fermes la connexion avant même d'appeler la Window1...forcément tu n'auras plus de connexion ouverte.

    Pour avoir une même connexion entre les différents formulaires, soit tu fais un singleton, soit tu passes ta connexion en paramètre aux formulaires qui en ont besoin.
    Personnellement, je trouve le singleton plus propre.

  3. #3
    Membre actif
    Homme Profil pro
    Inscrit en
    Mars 2011
    Messages
    48
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Mars 2011
    Messages : 48
    Par défaut
    Désolé je savais pas comment faire pour le code merci

    je suis débutant dans la programmation
    je ne sais pas ce que cest que le singleton

  4. #4
    Membre émérite
    Avatar de Gurdil le nain
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Avril 2009
    Messages
    468
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

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

    Informations forums :
    Inscription : Avril 2009
    Messages : 468
    Par défaut
    Si tu es débutant en programmation, une info pour toi :

    Sinon, voici un lien qui explique relativement simplement comment créé un singleton : http://webman.developpez.com/article...rns/singleton/

  5. #5
    Membre actif
    Homme Profil pro
    Inscrit en
    Mars 2011
    Messages
    48
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Mars 2011
    Messages : 48
    Par défaut
    Je vais essayer
    Merci

  6. #6
    Membre actif
    Homme Profil pro
    Inscrit en
    Mars 2011
    Messages
    48
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Mars 2011
    Messages : 48
    Par défaut
    J'ai passé mon aprem dessus mais je n'y arrive pas sa fait 3 jours que je taff sur cette parti je commence a perdre espoir

Discussions similaires

  1. Réponses: 1
    Dernier message: 17/06/2015, 17h52
  2. [Débutant] Appel d'une methode dans une methode
    Par yannoch123 dans le forum C#
    Réponses: 1
    Dernier message: 15/01/2014, 12h16
  3. Executer une methode dans un autre form
    Par pyannick03 dans le forum Windows Forms
    Réponses: 5
    Dernier message: 13/08/2010, 08h05
  4. comment avoir une valeur d'une form1 dans un autre form
    Par sabrina_beautyful dans le forum Windows Forms
    Réponses: 3
    Dernier message: 18/05/2009, 14h53
  5. Réponses: 7
    Dernier message: 17/01/2009, 13h10

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