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 :

INSERT INTO multiple ligne avec procédure stockée et DataGridView


Sujet :

C#

  1. #1
    Membre régulier
    Homme Profil pro
    ETUDE
    Inscrit en
    Septembre 2016
    Messages
    360
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Cameroun

    Informations professionnelles :
    Activité : ETUDE
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Septembre 2016
    Messages : 360
    Points : 117
    Points
    117
    Par défaut INSERT INTO multiple ligne avec procédure stockée et DataGridView
    Salut le forum j'ai écrit une commande qui permet d'insérer les données dans une table,
    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
     public string InsertVenteClient(VenteClients a)
            {
                string k;
                try
                {
     
                    d.connecter();
                    cmd.Connection = d.con;
                    cmd.CommandText = "spInsertVenteClient";
                    cmd.CommandType = CommandType.StoredProcedure;
                    cmd.Parameters.Clear();
                    cmd.Parameters.Add("@Dates", SqlDbType.DateTime).Value = a.Dates;
                    cmd.Parameters.Add("@IdDepot", SqlDbType.Int).Value = a.IdDepot;
                    cmd.Parameters.Add("@Idarticle", SqlDbType.Int).Value = a.Idarticle;
                    cmd.Parameters.Add("@IdAgences", SqlDbType.Int).Value = a.IdAgences;
                    cmd.Parameters.Add("@IdClients", SqlDbType.Int).Value = a.IdClients;
                    cmd.Parameters.Add("@IdUtilisateur", SqlDbType.Int).Value = a.IdUtilisateur;
                    cmd.Parameters.Add("@Numpiece", SqlDbType.NVarChar).Value = a.Numpiece;
                    cmd.Parameters.Add("@NumBC", SqlDbType.NVarChar).Value = a.NumBC;
                    cmd.Parameters.Add("@NumBL", SqlDbType.NVarChar).Value = a.NumBL;
                    cmd.Parameters.Add("@LIVRER", SqlDbType.NVarChar).Value = a.LIVRER;
                    cmd.Parameters.Add("@QUANTITE", SqlDbType.Decimal).Value = a.QUANTITE;
                    cmd.Parameters.Add("@PU", SqlDbType.Decimal).Value = a.PU;
     
                    SqlParameter para = new SqlParameter();
                    para.SqlDbType = SqlDbType.Int;
                    para.Direction = ParameterDirection.Output;
                    para.ParameterName = "@id";
                    cmd.Parameters.Add(para);
                    cmd.ExecuteNonQuery();
                    k = para.Value.ToString();
                }
                catch (Exception)
                {
                    k = "-1";
                }
                finally
                {
                    d.deconnecter();
                }
                return k;
            }
    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
      VenteClients p = new VenteClients();
           foreach(DataGridViewRow dr in dgvVenteclient.Rows)
                    {
                        p.IdAgences = Convert.ToInt32(dr.Cells[8].Value);
                        p.IdDepot = Convert.ToInt32(dr.Cells[7].Value);
                        p.Idarticle = Convert.ToInt32(dr.Cells[6].Value);
                        p.IdClients = Convert.ToInt32(dr.Cells[9].Value);
                        p.IdUtilisateur = Convert.ToInt32(dr.Cells[10].Value);
                        p.LIVRER =dr.Cells[5].Value.ToString();
                        p.QUANTITE =Convert.ToInt32(dr.Cells[2].Value);
                        p.PU = Convert.ToInt32(dr.Cells[3].Value);
                        p.Dates = Convert.ToDateTime(dr.Cells[0].Value);
                        p.NumBC = dr.Cells[12].Value.ToString(); 
                        p.NumBL = dr.Cells[13].Value.ToString();
                        p.Numpiece =dr.Cells[11].Value.ToString();
                    }
     
     
     
                    Insert j = new Insert();
                    string k = j.InsertVenteClient(p);
     
                    if (k == "-1")
                    {
     
                        MessageBox.Show("Rééssailler encore");
                    }
                    else
                    {
                        MessageBox.Show("Ajout effectué avec succés");
                    }
    le problème est que cela ne m'insert que la dernière ligne du Datagridview comment corrigé cela s'il vous plais

  2. #2
    Expert éminent sénior
    Homme Profil pro
    Responsable Données
    Inscrit en
    Janvier 2009
    Messages
    5 198
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Responsable Données

    Informations forums :
    Inscription : Janvier 2009
    Messages : 5 198
    Points : 12 774
    Points
    12 774
    Par défaut
    Bonjour,
    L'instruction insert est en dehors de la boucle, donc comme à chaque itération tu écrases les valeurs de la précédente, en sortie de la boucle tu n'as que les données de la dernière ligne...

    Tatayo.

  3. #3
    Membre régulier
    Homme Profil pro
    ETUDE
    Inscrit en
    Septembre 2016
    Messages
    360
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Cameroun

    Informations professionnelles :
    Activité : ETUDE
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Septembre 2016
    Messages : 360
    Points : 117
    Points
    117
    Par défaut
    Bonsoir tatayo merci beaucoup

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

Discussions similaires

  1. [MySQL] Insert into multiple : Répétition des valeurs en fonction du nombre de lignes
    Par Vinuto dans le forum PHP & Base de données
    Réponses: 8
    Dernier message: 10/02/2019, 15h48
  2. [11gR2] INSERT INTO .. VALUES lignes multiples
    Par al1_24 dans le forum SQL
    Réponses: 3
    Dernier message: 01/02/2016, 11h35
  3. Insertion de multiples lignes.
    Par ludvax dans le forum Oracle
    Réponses: 22
    Dernier message: 11/01/2010, 13h34
  4. C# récupérer l'id avec procédure stocké SQL Sserver 2000
    Par maximenet dans le forum Windows Forms
    Réponses: 5
    Dernier message: 10/04/2006, 23h17
  5. INSERT avec procédure stockée / Clef de type AutoInc
    Par bgdelphi dans le forum Bases de données
    Réponses: 5
    Dernier message: 18/10/2003, 18h30

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