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

MySQL Discussion :

IF permettant soit de faire un UPDATE soit un INSERT


Sujet :

MySQL

  1. #1
    SrK
    SrK est déconnecté
    Membre régulier
    Inscrit en
    Avril 2006
    Messages
    213
    Détails du profil
    Informations forums :
    Inscription : Avril 2006
    Messages : 213
    Points : 83
    Points
    83
    Par défaut IF permettant soit de faire un UPDATE soit un INSERT
    Bonjour,

    Voici mon problème:
    -je voudrai faire un UPDATE si l'élément existe en DB, sinon un INSERT.

    Pré-requis: ne pas faire de procédure stockée.

    A noter que je ne peux identifier mon élément par la clé primaire ou un index unique. ( donc pas de "REPLACE" ou "insert ... on duplicate key" possible à ma connaissance.

    Merki :p

    CODE avec une procédure stockée qui peut peut être illustrer le problème:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    DELIMITER //
    CREATE PROCEDURE test1234()
      BEGIN
    	IF (SELECT count(*) FROM maTable WHERE name LIKE '%test%' > 0)
    	THEN SELECT "UPDATE";
    	ELSE SELECT "INSERT";
    	END IF;
      END //
    DELIMITER ;
    CALL test1234();
    La différence entre la théorie et la pratique, c'est qu'en théorie, il n'y a pas de différence, mais qu'en pratique, il y en a une.

  2. #2
    ced
    ced est déconnecté
    Rédacteur/Modérateur

    Avatar de ced
    Homme Profil pro
    Gestion de bases de données techniques
    Inscrit en
    Avril 2002
    Messages
    6 016
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : Gestion de bases de données techniques
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Avril 2002
    Messages : 6 016
    Points : 23 705
    Points
    23 705
    Par défaut
    Bonjour,

    MySQL dispose de cette possibilité nativement, dans la syntaxe INSERT, avec la clause ON DUPLICATED KEY UPDATE...
    Plus d'infos dans la documentation de MySQL : http://dev.mysql.com/doc/refman/5.0/fr/insert.html

    ced
    Rédacteur / Modérateur SGBD et R
    Mes tutoriels et la FAQ MySQL

    ----------------------------------------------------
    Pensez aux balises code et au tag
    Une réponse vous a plu ? N'hésitez pas à y mettre un
    Je ne réponds pas aux questions techniques par message privé, les forums sont là pour ça

  3. #3
    SrK
    SrK est déconnecté
    Membre régulier
    Inscrit en
    Avril 2006
    Messages
    213
    Détails du profil
    Informations forums :
    Inscription : Avril 2006
    Messages : 213
    Points : 83
    Points
    83
    Par défaut
    Merci, mais comme indiqué dans mon message, je ne crois pas pouvoir faire de "insert ... on duplicate key" sachant que je n'ai pas la possibilité d'identifier mon élément par "une clé primaire" ou un "index unique", qui semble des pré-requis à l'utilisation de "insert ... on duplicate key" si je ne me trompe pas.
    La différence entre la théorie et la pratique, c'est qu'en théorie, il n'y a pas de différence, mais qu'en pratique, il y en a une.

  4. #4
    ced
    ced est déconnecté
    Rédacteur/Modérateur

    Avatar de ced
    Homme Profil pro
    Gestion de bases de données techniques
    Inscrit en
    Avril 2002
    Messages
    6 016
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : Gestion de bases de données techniques
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Avril 2002
    Messages : 6 016
    Points : 23 705
    Points
    23 705
    Par défaut
    Au temps pour moi, j'ai laissé passé ce "détail".
    Du coup, en SQL, ce n'est pas possible. Si tu ne veux pas de procédure, et si tu n'as pas de clé, alors il n'existe aucune instruction qui puisse te permettre de choisir entre un update et un insert selon le cas...
    En tout cas, pas à ma connaissance...

    ced
    Rédacteur / Modérateur SGBD et R
    Mes tutoriels et la FAQ MySQL

    ----------------------------------------------------
    Pensez aux balises code et au tag
    Une réponse vous a plu ? N'hésitez pas à y mettre un
    Je ne réponds pas aux questions techniques par message privé, les forums sont là pour ça

Discussions similaires

  1. Impossible de faire marcher ce soit disant "XAML Serialization" !
    Par nazimyenier dans le forum Windows Presentation Foundation
    Réponses: 6
    Dernier message: 31/08/2009, 21h18
  2. [MySQL] Soit un update soit un insert
    Par kerlochj dans le forum PHP & Base de données
    Réponses: 6
    Dernier message: 20/02/2008, 14h02
  3. Impossibilité de faire un update ou un insert
    Par nazimb dans le forum ASP.NET
    Réponses: 13
    Dernier message: 09/03/2006, 17h27
  4. Soit une liste de choix, soit un champ texte
    Par yoyot dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 14/02/2005, 14h37
  5. faire un update partiel
    Par danseur dans le forum SQL Procédural
    Réponses: 3
    Dernier message: 19/01/2004, 18h27

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