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 :

Lire/Ecrire d'une base de donnée access ( mdb )


Sujet :

Windows Forms

  1. #1
    Nouveau Candidat au Club
    Inscrit en
    Juillet 2007
    Messages
    1
    Détails du profil
    Informations forums :
    Inscription : Juillet 2007
    Messages : 1
    Points : 1
    Points
    1
    Par défaut Lire/Ecrire d'une base de donnée access ( mdb )
    Je fais une petite application qui se connecte à une base de donnée access, et je veux lire les champs de la base de donnée à partir d'un textbox/listbox.

    L'application contient un button pour "recherche" il recherche sur la base de donnée en se basant sur le champ "num".
    J'ai 8 champ, donc j'aurais besoin de 8 textbox/listbox. J'ai déjà essayer, et lorsque je compile y'a aucune erreur, mais quand j'éxcute le programme et je teste une recherche, il y'a une exception qui n'est pas gérée

    "indexOutOfRangeException n'a pas été gérée"
    Voila mon code, si y'a quelqun qui pourra me le corriger, je serais reconnaissant, à bientot, merci.


    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
    using System;
    using System.Collections.Generic;
    using System.ComponentModel;
    using System.Data;
    using System.Drawing;
    using System.Text;
    using System.Windows.Forms;
    using System.Data.OleDb;
     
    namespace WindowsApplication1
    {
        public partial class Form2 : Form
        {
            private OleDbConnection myconnection;
            private OleDbCommand command;
            private OleDbDataReader reader;
            private string strcon, strrequet;// variable pour la connection et la command
            public Form2()
            {
                InitializeComponent();
            }
     
            private void button1_Click(object sender, EventArgs e)
            {
                //regadre le form1_load c est le debut de programme 
     
                // ouvrire la connection 
                myconnection.Open();
                // requete sql 
                //le % ca veux dir * quand je lui donne les 1er letre kay kemel men 3andou 
     
     
                strrequet = "select NomFoncier, NTF, Superficie, DateAchat, Prix, NatureFoncier, Lieu from client where num like'" + textBox1.Text + "%'";
                command.CommandText = strrequet;
                // j affecte le resultat de la command a un objet reader oledbreader  
                reader = command.ExecuteReader();
                // tant que la lecture n est po fini je boucle pour afficher le resultat ds une listbox
                while (reader.Read())
                {
                    listBox1.Items.Add(reader["num"]);
     
                }
                myconnection.Close();
            }
     
            private void Form2_Load(object sender, EventArgs e)
            {
                //la chaine de connection rien a comprendre hiya hakdak 
                strcon = @"Provider=Microsoft.Jet.OLEDB.4.0; data Source=c:\test.mdb";
                myconnection = new OleDbConnection(strcon);
                command = new OleDbCommand(strrequet, myconnection);
            }
     
            private void button2_Click(object sender, EventArgs e)
            {
                listBox1.Items.Clear();
            }
        }
    }

  2. #2
    Rédacteur
    Avatar de SaumonAgile
    Homme Profil pro
    Team leader
    Inscrit en
    Avril 2007
    Messages
    4 028
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Team leader
    Secteur : Conseil

    Informations forums :
    Inscription : Avril 2007
    Messages : 4 028
    Points : 6 334
    Points
    6 334
    Par défaut
    Le champ num n'est pas retourné par ta requête alors que tu y fais référence quand tu lis le datareader.
    Besoin d'un MessageBox amélioré ? InformationBox pour .NET 1.1, 2.0, 3.0, 3.5, 4.0 sous license Apache 2.0.

    Bonnes pratiques pour les accès aux données
    Débogage efficace en .NET
    LINQ to Objects : l'envers du décor

    Mon profil LinkedIn - MCT - MCPD WinForms - MCTS Applications Distribuées - MCTS WCF - MCTS WCF 4.0 - MCTS SQL Server 2008, Database Development - Mon blog - Twitter

Discussions similaires

  1. [Débutant] Ecrire dans une base de donnée access
    Par Loic4891 dans le forum VB.NET
    Réponses: 4
    Dernier message: 01/02/2014, 18h28
  2. Lire une base de données access 2007 avec access 2003
    Par gblanchard dans le forum Runtime
    Réponses: 6
    Dernier message: 08/05/2007, 02h59
  3. [débutant] Connection à une base de donnée Access
    Par Lorenzox dans le forum JBuilder
    Réponses: 1
    Dernier message: 25/10/2004, 16h28
  4. Réponses: 15
    Dernier message: 25/10/2004, 11h50
  5. associer une base de données(access) a un dbgrid
    Par ange1708 dans le forum MFC
    Réponses: 3
    Dernier message: 11/06/2002, 12h18

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