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

VB.NET Discussion :

modification/ ajout ça marche pas


Sujet :

VB.NET

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre très actif
    Inscrit en
    Septembre 2010
    Messages
    168
    Détails du profil
    Informations personnelles :
    Âge : 39

    Informations forums :
    Inscription : Septembre 2010
    Messages : 168
    Par défaut modification/ ajout ça marche pas
    Bonjour tout le monde
    Voici mon problème le suivant:
    je veux ajouter des données à ma base de données
    -si l'enregistrement est déja dans le tableau il fait la modification si non il fait l'ajout

    voici mon 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
     Try
                'CBool(Me.DataGridView1.Rows(i).Cells("ART_REF").Value.ToString)
                con.Open()
                Dim i As Integer = Me.DataGridView1.Rows.Count - 2
                Dim trouve As Boolean
                Dim b As Integer
                If trouve = False Then
                    For b = 0 To i
                        cmd = New SqlCommand("select * from ARTICLE values('" & Me.DataGridView1.Rows(b).Cells("ART_REF").Value & "','" & Me.DataGridView1.Rows(b).Cells("ART_FAMILLE").Value & "','" & Me.DataGridView1.Rows(b).Cells("ART_DESEG").Value & "'," & Val(Me.DataGridView1.Rows(b).Cells("ART_PRIX_EURO").Value) & "," & Val(Me.DataGridView1.Rows(b).Cells("ART_PRIX_HT").Value) & ")", con)
                        cmd.ExecuteNonQuery()
                    Next
                Else
                    cmd1 = New SqlCommand("update ARTICLE set ART_FAMILLE='" & Me.DataGridView1.Rows(b).Cells("ART_FAMILLE").Value & "',ART_DESEG='" & Me.DataGridView1.Rows(b).Cells("ART_DESEG").Value & "',ART_PRIX_EURO=" & Val(Me.DataGridView1.Rows(b).Cells("ART_PRIX_EURO").Value) & ",ART_PRIX_HT=" & Val(Me.DataGridView1.Rows(b).Cells("ART_PRIX_HT").Value) & " where ART_REF='" & Me.DataGridView1.Rows(b).Cells("ART_REF").Value & "'", con)
                    cmd1.ExecuteNonQuery()
                End If
            Catch ex As Exception
                MsgBox(ex.Message)
            End Try
            con.Close()
    la modification ça amrche mais l'ajout ça marche pas aide moi svp
    Salutations

  2. #2
    Membre éclairé
    Profil pro
    Inscrit en
    Mars 2010
    Messages
    349
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2010
    Messages : 349
    Par défaut
    salut,

    si tu fais un select pour ajouter des données ça risque de ne jamais fonctionnait...

    Regarde plutôt du coté de " INSERT INTO "

  3. #3
    Membre éprouvé
    Homme Profil pro
    Responsable de service informatique
    Inscrit en
    Octobre 2010
    Messages
    62
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Responsable de service informatique
    Secteur : Transports

    Informations forums :
    Inscription : Octobre 2010
    Messages : 62
    Par défaut
    Bonjour,

    Vous avez oublié une partie du code à priori, tel que vous utilisez votre bool 'trouve', vous ne pouvez pas passer sur votre update.
    De plus je ne vois pas de code INSERT pour ajouter un enregistrement.

  4. #4
    Membre très actif
    Inscrit en
    Septembre 2010
    Messages
    168
    Détails du profil
    Informations personnelles :
    Âge : 39

    Informations forums :
    Inscription : Septembre 2010
    Messages : 168
    Par défaut
    re bonjour,
    merci à votre réponse mais ça marche pas pour la modification l'ajout ça marche
    voici mon 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
     Try
                'CBool(Me.DataGridView1.Rows(i).Cells("ART_REF").Value.ToString)
                con.Open()
                Dim i As Integer = Me.DataGridView1.Rows.Count - 2
                Dim trouve As Boolean
                Dim b As Integer
                If trouve = False Then
                    For b = 0 To i
                        cmd = New SqlCommand("insert into ARTICLE values('" & Me.DataGridView1.Rows(b).Cells("ART_REF").Value & "','" & Me.DataGridView1.Rows(b).Cells("ART_FAMILLE").Value & "','" & Me.DataGridView1.Rows(b).Cells("ART_DESEG").Value & "'," & Val(Me.DataGridView1.Rows(b).Cells("ART_PRIX_EURO").Value) & "," & Val(Me.DataGridView1.Rows(b).Cells("ART_PRIX_HT").Value) & ")", con)
                        cmd.ExecuteNonQuery()
                    Next
                Else
                    cmd1 = New SqlCommand("update ARTICLE set ART_FAMILLE='" & Me.DataGridView1.Rows(b).Cells("ART_FAMILLE").Value & "',ART_DESEG='" & Me.DataGridView1.Rows(b).Cells("ART_DESEG").Value & "',ART_PRIX_EURO=" & Val(Me.DataGridView1.Rows(b).Cells("ART_PRIX_EURO").Value) & ",ART_PRIX_HT=" & Val(Me.DataGridView1.Rows(b).Cells("ART_PRIX_HT").Value) & " where ART_REF='" & Me.DataGridView1.Rows(b).Cells("ART_REF").Value & "'", con)
                    cmd1.ExecuteNonQuery()
                End If
            Catch ex As Exception
                MsgBox(ex.Message)
            End Try
            con.Close()
    voici le message d"erreur:
    violation of primary key contraint 'PK_ARTICLE' cannot insert duplicate key in object 'ARTICLE'.
    The statement has been terminated
    ça veux dire il passe justement à la requete insert

  5. #5
    Membre éprouvé
    Homme Profil pro
    Responsable de service informatique
    Inscrit en
    Octobre 2010
    Messages
    62
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Responsable de service informatique
    Secteur : Transports

    Informations forums :
    Inscription : Octobre 2010
    Messages : 62
    Par défaut
    Vous créez votre variable 'trouve' mais vous ne la modifié jamais, votre condition sera toujours vrai et donc la commande insert sera toujours executé. Il faut ajouter une recherche dans la base pour mettre votre variable 'trouve' à vrai si la ligne existe.

  6. #6
    Membre très actif
    Inscrit en
    Septembre 2010
    Messages
    168
    Détails du profil
    Informations personnelles :
    Âge : 39

    Informations forums :
    Inscription : Septembre 2010
    Messages : 168
    Par défaut
    Bonjour,
    j'ai met le condition 'trouve' si =true il fait la modification sinon il fait l'insertion

Discussions similaires

  1. Modification paramètre CSS qui ne marche pas
    Par Kamoo dans le forum jQuery
    Réponses: 7
    Dernier message: 20/09/2012, 11h43
  2. [XCode] Double UITableView et bouton d'ajout qui ne marche pas
    Par zeon71 dans le forum XCode
    Réponses: 3
    Dernier message: 27/01/2012, 08h51
  3. Réponses: 2
    Dernier message: 26/03/2010, 09h55
  4. Requête modif dans formulaire ne marche pas
    Par crissud dans le forum IHM
    Réponses: 2
    Dernier message: 12/04/2007, 10h31
  5. Réponses: 13
    Dernier message: 14/09/2006, 21h30

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