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 :

[MySQL] INSERT IF NOT EXISTS


Sujet :

MySQL

  1. #1
    Membre du Club
    Inscrit en
    Janvier 2008
    Messages
    52
    Détails du profil
    Informations forums :
    Inscription : Janvier 2008
    Messages : 52
    Points : 41
    Points
    41
    Par défaut [MySQL] INSERT IF NOT EXISTS
    Bonjour à tous,

    Comme l'intitulé l'indique, je suis à la recherche d'une requête SQL me permettant d'insérer une ligne dans une table sous réserve de certaines conditions, ou plus exactement une condition.

    Je m'explique au travers d'un exemple. Soit la table 'test' suivante :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    +----+------+------+
    | id | text | num  |
    +----+------+------+
    |  1 | toto |   12 |
    |  2 | tata |   15 |
    |  3 | titi |   15 |
    |  4 | tutu |   32 |
    +----+------+------+
    La clé primaire de cette table est 'id' et est 'auto_increment'.

    Je souhaite pouvoir insérer dans cette table une nouvelle ligne si et seulement si le champ 'text' que je souhaite insérer n'existe pas déjà !

    exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    INSERT INTO test (id,text,num) VALUES (NULL,"toto",20) WHERE NOT EXISTS (SELECT id FROM test WHERE text = 'toto');
    Après recherches, je ne parviens pas à trouver comment faire... si quelqu'un peut m'aider... merci !

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

    Informations forums :
    Inscription : Mars 2010
    Messages : 51
    Points : 63
    Points
    63
    Par défaut
    Tu mets déjà une contrainte d'unicité sur le champs text.

    Ensuite tu fais des INSERT IGNORE INTO

    Et ils échouront si la clause d'unicité préalablement posée les en empêchent

  3. #3
    Membre du Club
    Inscrit en
    Janvier 2008
    Messages
    52
    Détails du profil
    Informations forums :
    Inscription : Janvier 2008
    Messages : 52
    Points : 41
    Points
    41
    Par défaut
    La table est déjà existante et je ne peux pas modifier sa structure !!

  4. #4
    Membre habitué
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    135
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 135
    Points : 164
    Points
    164
    Par défaut
    essaie ceci

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    INSERT INTO test (id,text,num) 
    SELECT distinct NULL,"toto",20 
    FROM test 
    WHERE text <> 'toto'

  5. #5
    Membre du Club
    Profil pro
    Inscrit en
    Mars 2010
    Messages
    51
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2010
    Messages : 51
    Points : 63
    Points
    63
    Par défaut
    Citation Envoyé par Iloyo Voir le message
    La table est déjà existante et je ne peux pas modifier sa structure !!
    On peut ajouter une contrainte d'unicité sur un table existante, ce n'est pas un problème.

    De toute façon, tu veux une unicité sur le champs "text", donc tu lui mets une contrainte UNIQUE, c'est tout ...

    Une autre solution serait du bidouillage :s

  6. #6
    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
    Citation Envoyé par Iloyo Voir le message
    Après recherches, je ne parviens pas à trouver comment faire... si quelqu'un peut m'aider... merci !
    Tout bêtement parce que ce que tu souhaites faire, ce n'est pas possible...
    La contrainte d'unicité peut être une alternative, ou alors c'est au code applicatif qui crée l'insertion de vérifier si la valeur existe déjà, mais en SQL direct, avec toutes les contraintes que tu donnes, tu ne peux pas.

    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

  7. #7
    Membre du Club
    Inscrit en
    Janvier 2008
    Messages
    52
    Détails du profil
    Informations forums :
    Inscription : Janvier 2008
    Messages : 52
    Points : 41
    Points
    41
    Par défaut
    Bon alors finalement j'essaye quelque chose de ce style :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    DELIMITER //
    	CREATE FUNCTION service_exist(s VARCHAR)
    	  RETURNS INT(11)
     
    	  BEGIN
    		IF (SELECT count(*) FROM urls WHERE text = s) = 0 THEN	RETURN 0;
    		ELSE RETURN 1;
    		END IF;
    	  END //
    DELIMITER ;
     
    IF service_exist("toto") = 0 THEN INSERT INTO urls (id,text,num) VALUES (NULL,"toto",10);
    Le tout étant dans un fichier ".sql". Cependant, lors de l'utilisation de mon fichier, j'obtiens les erreurs suivantes :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    DB Error : */ DELIMITER // CREATE FUNCTION service_exist(s VARCHAR) RETURNS INT(11) BEGIN IF (SELECT count(*) FROM urls WHERE text = s) = 0 THEN RETURN 0; [nativecode=1064 ** You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '*/ DELIMITER // CREATE FUNCTION service_exist(s VARCHAR) RETURNS INT(11) ' at line 1]
    DB Error : ELSE RETURN 1; [nativecode=1064 ** You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'ELSE RETURN 1' at line 1]
    DB Error : END IF; [nativecode=1064 ** You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'END IF' at line 1]
    DB Error : END // DELIMITER ; [nativecode=1064 ** You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'END // DELIMITER' at line 1]
    DB Error : IF service_exist("toto") = 0 THEN INSERT INTO urls (id,text,num) VALUES (NULL,"toto",10); [nativecode=1064 ** You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'IF service_exist("toto") = 0 THEN INSERT INTO urls (id,text,num) VALUES (NULL,"t' at line 1
    Je ne m'y connais pas suffisamment en SQL... si quelqu'un pouvait m'aider, ce serait avec grand plaisir !

    Merci !

  8. #8
    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
    Citation Envoyé par Iloyo Voir le message
    Le tout étant dans un fichier ".sql".
    Ça, c'est un élément nouveau ?
    Plutôt que de galérer avec un trigger, pourquoi ne pas insérer le contenu du fichier dans une table temporaire et ensuite faire l'insertion via un INSERT... SELECT... sur cette table temporaire en éliminant, par jointure externe dans la partie SELECT, les données déjà présentes ?
    Ça fait un peu moins "massue pour écraser une mouche", non ?

    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. INSERT IF NOT EXISTS
    Par finiderire dans le forum Langage SQL
    Réponses: 12
    Dernier message: 27/03/2012, 17h44
  2. Selection de lignes + insertion if not exists
    Par tom741 dans le forum SQL
    Réponses: 5
    Dernier message: 20/10/2010, 16h37
  3. Sunopsis ODI: Insertion if not exists
    Par Marie-Thérèse dans le forum ODI (ex-Sunopsis)
    Réponses: 1
    Dernier message: 06/08/2009, 10h43
  4. insert et not exists
    Par farenheiit dans le forum SQL
    Réponses: 3
    Dernier message: 10/07/2009, 16h45
  5. Insert .. where not exists
    Par Zolex dans le forum SQL Procédural
    Réponses: 11
    Dernier message: 02/03/2007, 11h26

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