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

Développement SQL Server Discussion :

Faire un insert value dans une table en vérifiant si la valeur existe déjà


Sujet :

Développement SQL Server

  1. #1
    Membre régulier
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Avril 2014
    Messages
    199
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Avril 2014
    Messages : 199
    Points : 70
    Points
    70
    Par défaut Faire un insert value dans une table en vérifiant si la valeur existe déjà
    Bonjour,

    Je voudrais insérer une valeur dans une table

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    insert into table (colone) VALUES ('value')
    Mais je voudrais faire cette insert uniquement si la valeur n'existe pas dans la base, et ceci dans la meme requete ?

    Comment faire cela? Est ce possible ?

    Merci
    Sylo

  2. #2
    Membre du Club
    Inscrit en
    Novembre 2010
    Messages
    80
    Détails du profil
    Informations forums :
    Inscription : Novembre 2010
    Messages : 80
    Points : 54
    Points
    54
    Par défaut
    Bonjour,
    Essaye-ça
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
     
    IF NOT EXISTS (select * from votre table where col='Valeur')
    BEGIN
        insert into table (colone) VALUES ('value')
    END

  3. #3
    Invité
    Invité(e)
    Par défaut
    Je pense que MERGE pourrait aussi faire l’affaire : https://msdn.microsoft.com/fr-ca/library/bb510625.aspx

  4. #4
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 770
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 21 770
    Points : 52 726
    Points
    52 726
    Billets dans le blog
    5
    Par défaut
    [QUOTE=olysmar2;8177489]Je voudrais insérer une valeur dans une table/QUOTE]

    Citation Envoyé par messi1987 Voir le message
    Bonjour,
    Essaye-ça
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
     
    IF NOT EXISTS (select * from votre table where col='Valeur')
    BEGIN
        insert into table (colone) VALUES ('value')
    END
    Non ça c'est stupide !

    Citation Envoyé par 7gyY9w1ZY6ySRgPeaefZ Voir le message
    Je pense que MERGE pourrait aussi faire l’affaire : https://msdn.microsoft.com/fr-ca/library/bb510625.aspx
    C'est déjà mieux, mais je pense pas que ce soit garantie !

    La seule solution viable c'est de mettre en place une contrainte d"unicité. En effet dans l'exemple de messi1987, si on lance le code en parallèle on obtiendra 2 fois la valeur. C'est pour cela que c'est stupide.
    Dans le cas de 7gyY9w1ZY6ySRgPeaefZ, même punition. Comme le MERGE dispatche entre INSERT ou UPDATE, mais commence par lire, il y a pose d'un verrou de lecture partagé le temps de faire la requête SELECT... Donc en concurrence ça ne fonctionne pas !

    C'est pour cela que les contraintes unicité ont été inventées !

    A +
    Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
    Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
    Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
    Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
    Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
    * * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *

  5. #5
    Membre du Club
    Inscrit en
    Novembre 2010
    Messages
    80
    Détails du profil
    Informations forums :
    Inscription : Novembre 2010
    Messages : 80
    Points : 54
    Points
    54
    Par défaut
    Citation Envoyé par SQLpro Voir le message
    La seule solution viable c'est de mettre en place une contrainte d"unicité. En effet dans l'exemple de messi1987, si on lance le code en parallèle on obtiendra 2 fois la valeur. C'est pour cela que c'est stupide.
    Dans le cas de 7gyY9w1ZY6ySRgPeaefZ, même punition. Comme le MERGE dispatche entre INSERT ou UPDATE, mais commence par lire, il y a pose d'un verrou de lecture partagé le temps de faire la requête SELECT... Donc en concurrence ça ne fonctionne pas !

    C'est pour cela que les contraintes unicité ont été inventées !

    A +
    SQLpro,Je vous remercie pour votre explication .

  6. #6
    Modérateur

    Profil pro
    dba
    Inscrit en
    Janvier 2010
    Messages
    5 643
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : dba

    Informations forums :
    Inscription : Janvier 2010
    Messages : 5 643
    Points : 13 092
    Points
    13 092
    Par défaut
    ou bien encore :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    INSERT INTO LaTable (LaColonne)
        SELECT 'value'
        WHERE NOT EXISTS(
            SELECT 1 FROM LaTable WHERE LaColonne = 'value'
        )
    ;

  7. #7
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 770
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 21 770
    Points : 52 726
    Points
    52 726
    Billets dans le blog
    5
    Par défaut
    Citation Envoyé par aieeeuuuuu Voir le message
    ou bien encore :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    INSERT INTO LaTable (LaColonne)
        SELECT 'value'
        WHERE NOT EXISTS(
            SELECT 1 FROM LaTable WHERE LaColonne = 'value'
        )
    ;
    NON !!!! Pour les mêmes raisons... Cela ne peut marcher que si tu es en mode d'isolation SERIALIZABLE, empêchant l'apparition de lignes fantômes. Car deux personnes qui font cela au même instant vont se retrouver avec les mêmes valeurs.....

    A +
    Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
    Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
    Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
    Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
    Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
    * * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *

  8. #8
    Modérateur

    Profil pro
    dba
    Inscrit en
    Janvier 2010
    Messages
    5 643
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : dba

    Informations forums :
    Inscription : Janvier 2010
    Messages : 5 643
    Points : 13 092
    Points
    13 092
    Par défaut
    Citation Envoyé par SQLpro Voir le message
    NON !!!! Pour les mêmes raisons... Cela ne peut marcher que si tu es en mode d'isolation SERIALIZABLE,

    En effet !!

  9. #9
    Membre régulier
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Avril 2014
    Messages
    199
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Avril 2014
    Messages : 199
    Points : 70
    Points
    70
    Par défaut
    ok merci, pour vos retour
    Je vois qu'il n'y a pas de solution simple
    Donc je vais faire cela en deux passe
    MErci
    Sylo

Discussions similaires

  1. Insert Into dans une table avec select
    Par smail25 dans le forum Langage SQL
    Réponses: 2
    Dernier message: 15/12/2006, 13h06
  2. [VRML] Faire des trous ronds dans une table.
    Par yoyo910 dans le forum Développement 2D, 3D et Jeux
    Réponses: 2
    Dernier message: 22/03/2006, 17h56
  3. Insertion directe dans une table
    Par zzinfo dans le forum SQL
    Réponses: 2
    Dernier message: 28/02/2006, 15h17
  4. [9i] insertion sequentiel dans une table
    Par djalil dans le forum Oracle
    Réponses: 4
    Dernier message: 17/11/2005, 19h06
  5. [JSP]probleme d'insertion float dans une table
    Par karamazov994 dans le forum Servlets/JSP
    Réponses: 2
    Dernier message: 14/04/2005, 11h49

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