Je commence le C# depuis peu, et la POO, autant vous le dire maintenant, je ne l'utilise pas entièrement...
Je réalise une appli en ce moment qui comprends ces étapes:

-ouverture fichier texte
-récupérations de données spécifiques dans ce fichier
-affichage de ces données dans un datagridview
-connexion MySql en entrant les paramètres
-execution de requetes sql via une TextBox
-affichage de la requete dans un datagrid relié à un dataset.

Mon problème numéro 1: mon code est pas très... POO en fait, et je n'arrive pas à bien utiliser les classes et tout...quelqu'un pourrait m'aider un peu?

Mon problème numéro2: je n'arrive pas à "prendre" les données récupérées du .txt et affichées ds le 1er datagridciew, et automatiquement les mettre ds ma base via "insert into...". Voilà 2 jours plein temps que je suis dessus et impossible d'y arriver...

mon code:
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
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
 
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using MySql.Data;
using MySql.Data.MySqlClient;
using System.IO;
 
namespace WindowsFormsApplication1
{
    public partial class Form1 : Form
    {
        //Variables globales
        string var1, var2, var3, path;
 
        //instanciation de la conenxion et du dataset
        private MySqlConnection Connection = new MySqlConnection();
        private MySqlDataAdapter MyAdapter = new MySqlDataAdapter();
        private DataSet ds = new DataSet();
 
 
        public Form1()
        {
            InitializeComponent();
        }
 
        private void PopulateDataGridView()
        {
            // mise en tableau des 3 données
            string[] row0 = { var1, var2, var3 };
            // mise en grid du tableau
            dataGridView1.Rows.Add(row0);
            //dataGridView1.Columns[0].DisplayIndex = 1;
        }
 
        private void btpath_Click(object sender, EventArgs e)
        {
            OpenFileDialog fdlg = new OpenFileDialog();
            fdlg.Title = "Fichier Produits";
            fdlg.InitialDirectory = @"c:\";
            fdlg.Filter = "Fichier Texte | *.txt";
            fdlg.FilterIndex = 2;
            fdlg.RestoreDirectory = true;
            if (fdlg.ShowDialog() == DialogResult.OK)
            {
                tbpath.Text = fdlg.FileName;
                path = fdlg.FileName;
            }
        }
 
        private void btlire_Click(object sender, EventArgs e)
        {
            //donne le chemin et le nom du fichier au constructeur StreamReader
            FileStream fs = new FileStream(path, FileMode.Open);
            StreamReader sr = new StreamReader(fs, Encoding.UTF8);
            string ligne;
 
            //lit la première ligne du texte
            ligne = sr.ReadLine();
 
            //continue de lire jusqu'à la fin du fichier
            while (ligne != null)
            {
                var1 = ""; var2 = ""; var3 = "";
 
                //on passe à la ligne suivante
                ligne = sr.ReadLine();
 
 
                if (ligne == "#CART")
                {
                    // Boucle de récupération par redondance des intervals de lignes
                    for (int compteur = 0; compteur < 14; ligne = sr.ReadLine(), compteur++)
 
                        switch (compteur)
                        {
                            case 1:
                                var1 = ligne;
                                break;
                            case 2:
                                var2 = ligne;
                                break;
                            case 13:
                                var3 = ligne;
                                break;
                        }
                    // Affichage dans la text box une vérif des données récupérées
                    tbpath.Text += "\t\r  " + var1 + "\t\r  " + var2 + "\t\r  " + var3;
 
                    // Appel de la méthode Populate
                    PopulateDataGridView();
 
                }
            }
 
            //ferme le fichier
            sr.Close();
            fs.Close();
        }
 
        private void btconnect_Click(object sender, EventArgs e)
        {
            //Reset de la ConnectionString
            string ConnnectionStr = String.Empty;
 
            if ((tbhote.Text.Length == 0) || (tbbase.Text.Length == 0) || (tblogin.Text.Length == 0))
            {
                //Message d'erreur si champs non remplis
                MessageBox.Show("Erreur, les champs Hôte, Base et Login doivent être remplis", "Erreur",
                MessageBoxButtons.OK, MessageBoxIcon.Error);
            }
            else
			{
				// On définit la chaine de connexion
			 ConnnectionStr = "Database=" + tbbase.Text + ";Data Source=" + tbhote.Text + ";User=" + tblogin.Text + ";Password=" + tbpwd.Text;
			}
 
            Connection.ConnectionString = ConnnectionStr;
 
            try
            {
                // On ouvre la connexion
				Connection.Open();
            }
            catch (MySqlException Ex)
            {
                MessageBox.Show("Erreur SQL:\n" + Ex.Message, "Erreur", MessageBoxButtons.OK, MessageBoxIcon.Error);
            }
 
                MessageBox.Show("Vous êtes maintenant connecté à la Base de Données " + tbbase.Text + ". Vous pouvez désormais éxécuter vos requêtes SQL!", "Connexion Réussie!", MessageBoxButtons.OK);
                MessageBox.Show("Si vous n'éxécutez pas de requêtes SQL, n'oubliez pas de vous DECONNECTER de la base!", "ATTENTION ! ", MessageBoxButtons.OK, MessageBoxIcon.Exclamation);
        }
 
        private void execsql_Click(object sender, EventArgs e)
        {
            // On définit la requête SELECT à exécuter
            string MySQLCmd = tbsql.Text;
 
            // On associe cette requête à la propriété SelectCommand du MySqlDataAdapter
            MyAdapter.SelectCommand = new MySqlCommand(MySQLCmd, Connection);
 
            // On remplit le dataset avec le résultat de la commande SELECT
            MyAdapter.Fill(ds);
 
            // On affiche le datagrid
            dataGrid1.DataSource = ds.Tables[0];
            dataGrid1.Refresh();
 
            // On ferme la connexion le plus tôt possible
            Connection.Close();
        }
 
        private void btclear_Click(object sender, EventArgs e)
        {
            ds.Clear();
        }
 
        private void btdeconnect_Click(object sender, EventArgs e)
        {
            // On ferme la connexion le plus tôt possible
            Connection.Close();
        }
 
    }
}
Merci de m'aider un peu svp...je coince là! :s