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 :

[SQL // ADO.NET] instruction INSERT INTO dans une boucle for


Sujet :

C#

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Juin 2010
    Messages
    40
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2010
    Messages : 40
    Points : 30
    Points
    30
    Par défaut [SQL // ADO.NET] instruction INSERT INTO dans une boucle for
    Bonsoir à toutes et à tous!

    Je travaille actuellement sur l'élaboration d'un logiciel capable de générer des devis et des factures à travers l'utilisation de dataGridView.Je dispose pour cela d'une base de données ACCESS...

    Je m'interroge de plus en plus sur la possibilité d'incorporer une instruction INSERT dans une boucle for.


    • -A partir d'un 1er datagridview nommé dataGridView1, j'affiche les produits que l'entreprise vends aux particulier, et cela grace à la table "SERVICES" de ma BDD. Ces produits constituent ainsi les produits que le client se voit facturer.
    • -A laide d'un bouton "ajouter" j'utiliser les instructions INSERT afin d'inserer mes produits dans les tables FACTURER(NumFacture,NumService,qte)

    Et avec l'aide d'autre tables, j'établi une facture comprenant les services vendus et autres choses diverses et variées.

    En fait ce que je voudrais faire est la chose suivante:

    a partir d'un deuxième datagridview comprenant les produits séléctionnés dans le datagridview1, je cherche a enregistrer les produits dans ma table facturer grace a une boucle for qui parcours mon datagridview2.

    voici le 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
    for (i = 0; i < (dataGridView2.Rows.Count - 1); i++)
                    {
                        service = Convert.ToString(dataGridView2[1, i].Value);//Nom du produit
                        qte = Convert.ToInt16(dataGridView2[3, i].Value);//qté commandée
     
                        OleDbCommand sel = new OleDbCommand("SELECT NumService FROM SERVICES WHERE NomService='" + service + "'", co);
                        ns = Convert.ToInt16(sel.ExecuteScalar());//récupération du Numéro de produit correspondant au nom du produit correspondant
     
                        OleDbCommand insFacrer = new OleDbCommand("INSERT INTO FACTURER VALUES(@nf,@ns,@qte)", co);
                        insFacrer.Parameters.Add("@nf", OleDbType.Integer);//Numéro de facture
                        insFacrer.Parameters.Add("@ns", OleDbType.Integer);//Numéro de service
                        insFacrer.Parameters.Add("@qte", OleDbType.Integer);//quantité facturée pour le client
     
                        insFacrer.Parameters["@nf"].Value = fact2;
                        insFacrer.Parameters["@ns"].Value = ns;
                        insFacrer.Parameters["@qte"].Value = qte;
     
                        insFacrer.ExecuteNonQuery();
                        Da.InsertCommand = insFacrer;
                        co.Close();
                    }
    Le résultat est que cela ne fait rien du tout... Je me creuse la tête depuis plusieurs heures sans pouvoir trouver la solution...

    Peut-être est-ce un problème d'instruction INSERT, mais je ne vois pas où il pourrait-être...

    Quand a la possibilité d'utiliser un foreach, je n'est pas réussi a bien me servir de cette expression...

    En espérant une réponse rapide,
    je vous remercie d'avance.

  2. #2
    Rédacteur/Modérateur


    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2004
    Messages
    19 875
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Paris (Île de France)

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

    Informations forums :
    Inscription : Février 2004
    Messages : 19 875
    Points : 39 749
    Points
    39 749
    Par défaut
    Je ne vois rien de fondamentalement incorrect dans ton code... à part peut-être cette ligne dont je ne vois pas l'utilité :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Da.InsertCommand = insFacrer;
    Mais ce n'est sûrement pas ça qui cause le problème.

    Le fait que ce soit dans une boucle for n'a a priori aucun rapport non plus avec le problème.

    Est-ce que tu ne serais pas dans une transaction que tu n'aurais pas commité ?

    Est-ce que ta base de données appartient au projet ? Si oui, vérifie qu'il n'y a pas l'option "Copier dans le répertoire de sortie" réglée sur "Toujours copier". Si c'est le cas, la base dans le répertoire de travail est écrasée à chaque recompilation...

    Sinon, tu as essayé d'exécuter en pas-à-pas ? Regarde la valeur de retour de ExecuteNonQuery, ça indique le nombre de lignes insérées.

    EDIT: Ah si, y a un truc louche quand même : tu fermes la connexion à chaque itération... donc a priori seule la première requête devrait passer, les autres devraient déclencher une exception. Si ce n'est pas le cas, c'est probablement que tu ne rentres jamais dans la boucle...

  3. #3
    Expert éminent Avatar de Graffito
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    5 993
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 5 993
    Points : 7 903
    Points
    7 903
    Par défaut
    Le résultat est que cela ne fait rien du tout...
    Dans la base ou dans ton IHM ?

    Quels sont les champs de la table FACTURER ?
    " Le croquemitaine ! Aaaaaah ! Où ça ? " ©Homer Simpson

  4. #4
    Membre régulier Avatar de SetaSensei
    Homme Profil pro
    Inscrit en
    Juin 2006
    Messages
    78
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 78
    Points : 104
    Points
    104
    Par défaut
    Bonjour,

    Je vais partir du postulat que vous ne voyez pas l'insertion dans votre appli. Car comme l'a indiqué Graffito, vous pouvez avoir plusieurs types d'erreur vu le message que vous avez posté.

    Je suppose que vous utilisez un DataSet pour populariser le DataSource de votre DataGridView. Si vous fermez votre connexion une fois le DataSet rempli (j'espère que c'est ce que vous faites ), les données ne sont pas mises à jour sur le poste client.
    Du coup, si vous effectuez des modifications sur la BDD mais que votre DataSource n'est pas rafraîchi, vous ne voyez pas le résultat de votre requête.
    Il faut donc relancer la population de votre DataGridView depuis une nouvelle connexion à la BDD.
    Si vous ne voyez pas de résultat en base non plus, le problème est autre. Notamment le :
    qui empêche, comme l'a dit tomlev. Mais normalement vous auriez dû enregistrer une ligne pour chaque facture.

  5. #5
    Rédacteur/Modérateur


    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2004
    Messages
    19 875
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Paris (Île de France)

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

    Informations forums :
    Inscription : Février 2004
    Messages : 19 875
    Points : 39 749
    Points
    39 749
    Par défaut
    Citation Envoyé par SetaSensei Voir le message
    Je suppose que vous utilisez un DataSet pour populariser le DataSource de votre DataGridView
    Il me semble que c'est une traduction un peu foireuse du terme anglais "populate"
    J'aurais dis "peupler", ou "remplir", tout simplement


    Sinon c'est une théorie qui se tient, j'y avais pas pensé... on va voir si le PO confirme

  6. #6
    Membre régulier Avatar de SetaSensei
    Homme Profil pro
    Inscrit en
    Juin 2006
    Messages
    78
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 78
    Points : 104
    Points
    104
    Par défaut
    Citation Envoyé par tomlev Voir le message
    Il me semble que c'est une traduction un peu foireuse du terme anglais "populate"
    J'aurais dis "peupler", ou "remplir", tout simplement


    Sinon c'est une théorie qui se tient, j'y avais pas pensé... on va voir si le PO confirme
    Désolé, pas encore pris mes 2 litres de café...

  7. #7
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Juin 2010
    Messages
    40
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2010
    Messages : 40
    Points : 30
    Points
    30
    Par défaut
    Bonjour a tous,

    Merci a tous d'avoir répondu a mon problème aussi vite!

    Donc, j'ai bien regardé, et Tonlev avait raison, mais partiellement... Une étourderie s'étais glissé dans mon code, mais vous ne pouviez pas le savoir...

    Alors, certes, le co.close() est un problème , ainsi donc, je l'ai sorti de ma boucle,avec le co.Open(). Plus aucun souci a se faire de ce coté-ci.

    Ma principale erreur, que je n'ai pas vu hier, (evidemment avec 5 heures de boulot non-stop l'après midi, on commence a faire un peu n'importe quoi avec son code...) était le fait que je ne piochait pas les bonnes valeurs dans mon dataGridView2. En fait, je me suis trompé de colonne, ce n'était pas:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    service = Convert.ToString(dataGridView2[1, i].Value);
                        qte = Convert.ToInt16(dataGridView2[3, i].Value);
    mais bien:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    service = Convert.ToString(dataGridView2[2, i].Value);
                        qte = Convert.ToInt16(dataGridView2[4, i].Value);
    Donc, pour ne pas me faire culpabiliser de vous avoir fait perdre votre temps, je vous remercie sincèrement de m'avoir aidé dans la recherche de mes erreurs...

    Vous me sauvez la vie vous savez?
    Bonne journée a vous tous! Et soyez fort!

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [PHP 5.2] 34000 insert into dans une boucle, bloquage à 32768 !
    Par Dsphinx dans le forum Langage
    Réponses: 29
    Dernier message: 11/06/2013, 15h57
  2. [MySQL] INSERT INTO dans une boucle
    Par andaman dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 08/05/2013, 16h39
  3. INSERT INTO dans une table vide
    Par DeepXtaZy dans le forum Requêtes et SQL.
    Réponses: 2
    Dernier message: 22/06/2007, 08h37
  4. Recordset pour INSERT INTO dans une table vide
    Par tAKAmAkA dans le forum VBA Access
    Réponses: 12
    Dernier message: 09/02/2007, 20h52
  5. Insert Into dans une table avec select
    Par smail25 dans le forum Langage SQL
    Réponses: 2
    Dernier message: 15/12/2006, 13h06

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