| 12
 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();
        }
 
    }
} |