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