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 ou update sur table mysql


Sujet :

C#

  1. #1
    Membre actif
    Homme Profil pro
    Inscrit en
    Mars 2011
    Messages
    48
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Mars 2011
    Messages : 48
    Par défaut Insert ou update sur table mysql
    Bonjour,

    J'aimerais que mon application sache a qu'elle moment il doit ecrire ou modifier mes champs dans ma table de donnée

    j'ai essayé plusieur chose mais je n'y arrive pas.

    j'ai trouvé ceci sur le net

    INSERT INTO table (a,b,c) VALUES (1,2,3),(4,5,6)
    -> ON DUPLICATE KEY UPDATE c=VALUES(a)+VALUES(b)
    http://dev.mysql.com/doc/refman/4.1/en/insert.html

    En alternative il y a également la fonction replace décrite sur
    http://dev.mysql.com/doc/refman/5.0/fr/replace.html
    Je n'arrive pas a l'interpréter

    je mets un morceau de mon code

    Pouvez vous m'aider svp?

    Merci a tous


    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
     
    using (wConnexion)
                {
                    // Instancier l’objet Command
                    using (MySqlCommand wCommand = wConnexion.CreateCommand())
                    {
     
     
     
                            // UPDATE de la requette
                            wCommand.CommandText = "UPDATE `test` SET nom=@nom, prenom=@prenom, message=@message, sexe=@sexe";
                            wCommand.Parameters.AddWithValue("@nom", textBox2.Text);
                            wCommand.Parameters.AddWithValue("@prenom", textBox3.Text);
                            wCommand.Parameters.AddWithValue("@message", textBox4.Text);
                            wCommand.Parameters.AddWithValue("@sexe", comboBox2.Text);
     
     
                            // Insert de la requête
                            wCommand.CommandText = "INSERT INTO test (nom, prenom, message, sexe) VALUES (@nom, @prenom, @message, @sexe)";
                            wCommand.Parameters.AddWithValue("@nom", textBox2.Text);
                            wCommand.Parameters.AddWithValue("@prenom", textBox3.Text);
                            wCommand.Parameters.AddWithValue("@message", textBox4.Text);
                            wCommand.Parameters.AddWithValue("@sexe", comboBox2.Text);
     
     
                            // Exécution de la requête
                        try
                        {
                          wCommand.ExecuteNonQuery();
                            MessageBox.Show("Enregistrement effectué!");
                        }
                        catch (InvalidOperationException)
                        {
                            MessageBox.Show("Erreur impossible d'écrire dans la table!");
     
                        }

  2. #2
    Membre Expert
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Novembre 2010
    Messages
    793
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Mayenne (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Novembre 2010
    Messages : 793
    Par défaut
    Quel(le) est ton problème/erreur avec ce code ?

  3. #3
    Membre actif
    Homme Profil pro
    Inscrit en
    Mars 2011
    Messages
    48
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Mars 2011
    Messages : 48
    Par défaut
    Mon problème est le suivant

    j'aimerais que mon programme sache a quelle moment il doit faire un update dans ma base ou un insert.

    j'ai essayé le try catch mais ca marche pas j'ai essayé aussi le if avec else mais pareil sa marche pas

  4. #4
    Expert confirmé 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
    Par défaut
    Il y a un problème de principe dans ce que tu l'as exposé :
    un ajout est toujours possible et, si la table n'est pas vide, une modification est toujours possible.

    Pour une command UPDATE, il faudrait dèjà une clause WHERE qui identifie de façon unique l'enregistrement à modifier.

    Une fois la commande UPDATE définie, on peut créer 2 mySqlCommand : lnsertCommand et UpdateCommand et faire ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    bool Ok=UpdateCommand.ExecuteNonQuery()==1 || lnsertCommand.ExecuteNonQuery()==1 ;

  5. #5
    Membre actif
    Homme Profil pro
    Inscrit en
    Mars 2011
    Messages
    48
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Mars 2011
    Messages : 48
    Par défaut
    Je n'ai pas compris
    Peux tu m'expliquer un peu plus s'il te plait?
    Je suis débutant

  6. #6
    Membre Expert
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Novembre 2010
    Messages
    793
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Mayenne (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Novembre 2010
    Messages : 793
    Par défaut
    Je pense mieux comprendre ce que tu souhaites, tu souhaiterais faire un Update si le nom/prenom existe, ou un insert si ce n'est pas le cas ?
    Si c'est bien ce que tu cherches, fais un "Select count" préalable avec ton nom/prenom, si le count te renvoie 0, tu fais l'insert, s'il te renvoie 1 tu fais l'Update.

    Mais comme l'a dit Graffito, n'oublie pas de préciser un where dans ta requête d'Update avec le nom/prenom

  7. #7
    Membre actif
    Homme Profil pro
    Inscrit en
    Mars 2011
    Messages
    48
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Mars 2011
    Messages : 48
    Par défaut
    Oui c'est bien ce que je veux.
    Vous connaissez un site qui explique cela?

Discussions similaires

  1. Réponses: 4
    Dernier message: 05/04/2011, 08h32
  2. Erreur 145 sur table mysql
    Par ramses83 dans le forum Requêtes
    Réponses: 1
    Dernier message: 06/09/2007, 21h09
  3. ERROR: insert or update on table "ecole" violate
    Par doulel dans le forum PostgreSQL
    Réponses: 1
    Dernier message: 17/04/2006, 21h24
  4. ERROR:insert or update on table "ecol" violates fo
    Par doulel dans le forum Langage SQL
    Réponses: 3
    Dernier message: 16/04/2006, 10h19
  5. Insert avec select sur table avec Trigger d'insertion
    Par bran_noz dans le forum Développement
    Réponses: 5
    Dernier message: 23/12/2005, 14h38

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