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

SQL Firebird Discussion :

INSERT enregistrement si il n'existe pas


Sujet :

SQL Firebird

  1. #1
    Membre régulier
    Homme Profil pro
    Étudiant
    Inscrit en
    Février 2019
    Messages
    182
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Aveyron (Midi Pyrénées)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2019
    Messages : 182
    Points : 84
    Points
    84
    Par défaut INSERT enregistrement si il n'existe pas
    salut j'ai un table etudiantes contient 3 enregistrements (clé primaire est: N_INSCRIPTION)

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    INSERT INTO Table02 (N_INSCRIPTION)
    SELECT N_INSCRIPTION FROM etudiantes
    WHERE CODE_Specialite='info'
    AND sex='m'
    l’exécution de cette requête est bient

    Mais quand j'ajoute le quatrième enregistrement dans la table etudiantes et exécuter la requête ça ne marche pas
    car les 3 enregistrements Ils ont été précédemment ajoutés au tableau (Table02) (violation of PRIMARY or UNIQUE KEY constraint) c'est ça le problème

    Comment ajouter les nouveaux enregistrements qui ont été ajoutés ?
    J'ai fait cette requête pour essayer mais cela n'a pas fonctionné
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    INSERT INTO Table02 (N_INSCRIPTION)
    SELECT N_INSCRIPTION FROM etudiantes
    WHERE CODE_Specialite='info'
    AND sex='m'
     
     Where Not Exists
           (
             Select N_INSCRIPTION
               From Table02
           );
    Delphi installés : RAD Studio 10.4.1 ..........Programme VCL
    SGBD : Firebird 2.5
    générateurs Etats : FastReport, QuickReport
    OS : Window 10 64bit

  2. #2
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 080
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Retraité
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2002
    Messages : 9 080
    Points : 30 790
    Points
    30 790
    Par défaut
    Citation Envoyé par delphi2019 Voir le message
    J'ai fait cette requête pour essayer mais cela n'a pas fonctionné
    Tu reçois un message d'erreur ?
    L'insertion ne s'effectue pas ?
    Modérateur Langage SQL
    Règles du forum Langage SQL à lire par tous, N'hésitez pas à consulter les cours SQL
    N'oubliez pas le bouton et pensez aux balises
    [code]
    Si une réponse vous a aidé à résoudre votre problème, n'oubliez pas de voter pour elle en cliquant sur
    Aide-toi et le forum t'aidera : Un problème exposé sans mentionner les tentatives de résolution infructueuses peut laisser supposer que le posteur attend qu'on fasse son travail à sa place... et ne donne pas envie d'y répondre.

  3. #3
    Membre régulier
    Homme Profil pro
    Étudiant
    Inscrit en
    Février 2019
    Messages
    182
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Aveyron (Midi Pyrénées)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2019
    Messages : 182
    Points : 84
    Points
    84
    Par défaut
    Un message d'erreur s'affiche car la requête contient deux where
    Delphi installés : RAD Studio 10.4.1 ..........Programme VCL
    SGBD : Firebird 2.5
    générateurs Etats : FastReport, QuickReport
    OS : Window 10 64bit

  4. #4
    Membre éprouvé
    Profil pro
    Inscrit en
    Janvier 2009
    Messages
    566
    Détails du profil
    Informations personnelles :
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Secteur : Finance

    Informations forums :
    Inscription : Janvier 2009
    Messages : 566
    Points : 1 045
    Points
    1 045
    Par défaut
    Bonjour,

    Il me semble que si tu présentais ta requête ainsi, elle fonctionnerait :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    INSERT INTO Table02 a (N_INSCRIPTION)
    SELECT N_INSCRIPTION FROM etudiantes
    WHERE 
       CODE_Specialite='info'
       AND sex='m'
       AND Not Exists ( Select * From Table02 b WHERE a.N_INSCRIPTION = b.N_INSCRIPTION );
    N'ayant pas la présentation des tables de la base, il est possible qu'il reste quelques détails à solutionner, mais le principe est là.
    Faire attention aux alias. J'ai fait des ajouts avec les alias a et b.
    Bon courage.

  5. #5
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 080
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Retraité
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2002
    Messages : 9 080
    Points : 30 790
    Points
    30 790
    Par défaut
    Petite correction sur la requête de seabs :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    INSERT INTO Table02 (N_INSCRIPTION)
    SELECT N_INSCRIPTION FROM etudiantes a
    WHERE 
       CODE_Specialite='info'
       AND sex='m'
       AND Not Exists ( Select * From Table02 b WHERE a.N_INSCRIPTION = b.N_INSCRIPTION );
    Sinon tu peux aussi écrire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    INSERT INTO Table02 (N_INSCRIPTION)
    SELECT N_INSCRIPTION FROM etudiantes
    WHERE CODE_Specialite='info'
    AND sex='m'
    AND N_INSCRIPTION Not In
            ( Select N_INSCRIPTION
               From Table02
           );
    Modérateur Langage SQL
    Règles du forum Langage SQL à lire par tous, N'hésitez pas à consulter les cours SQL
    N'oubliez pas le bouton et pensez aux balises
    [code]
    Si une réponse vous a aidé à résoudre votre problème, n'oubliez pas de voter pour elle en cliquant sur
    Aide-toi et le forum t'aidera : Un problème exposé sans mentionner les tentatives de résolution infructueuses peut laisser supposer que le posteur attend qu'on fasse son travail à sa place... et ne donne pas envie d'y répondre.

  6. #6
    Membre régulier
    Homme Profil pro
    Étudiant
    Inscrit en
    Février 2019
    Messages
    182
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Aveyron (Midi Pyrénées)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2019
    Messages : 182
    Points : 84
    Points
    84
    Par défaut
    merci C'est la solution
    Delphi installés : RAD Studio 10.4.1 ..........Programme VCL
    SGBD : Firebird 2.5
    générateurs Etats : FastReport, QuickReport
    OS : Window 10 64bit

  7. #7
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 080
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Retraité
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2002
    Messages : 9 080
    Points : 30 790
    Points
    30 790
    Par défaut
    J'avais oublié une troisième solution :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    INSERT INTO Table02 (N_INSCRIPTION)
    SELECT  N_INSCRIPTION
    FROM    etudiantes
    WHERE   CODE_Specialite='info'
        AND sex='m'
    EXCEPT
       Select  N_INSCRIPTION
       From    Table02
    ;
    Modérateur Langage SQL
    Règles du forum Langage SQL à lire par tous, N'hésitez pas à consulter les cours SQL
    N'oubliez pas le bouton et pensez aux balises
    [code]
    Si une réponse vous a aidé à résoudre votre problème, n'oubliez pas de voter pour elle en cliquant sur
    Aide-toi et le forum t'aidera : Un problème exposé sans mentionner les tentatives de résolution infructueuses peut laisser supposer que le posteur attend qu'on fasse son travail à sa place... et ne donne pas envie d'y répondre.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. insertion des numéros qui n'existe pas dans la base de données
    Par cisco.nat dans le forum Général Java
    Réponses: 5
    Dernier message: 09/07/2013, 12h39
  2. Insert si l'enregistrement n'existe pas deja
    Par Joel Pinto Ribeiro dans le forum Requêtes
    Réponses: 4
    Dernier message: 19/12/2012, 13h45
  3. [AC-2010] Créer un enregistrement si il n'existe pas
    Par Daejung dans le forum VBA Access
    Réponses: 2
    Dernier message: 29/12/2011, 18h42
  4. Insertion si la ligne n'existe pas
    Par hammag dans le forum SQL
    Réponses: 1
    Dernier message: 17/08/2011, 17h20
  5. [MySQL] Boucle et INSERT si la ligne n'existe pas
    Par yazerty dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 25/09/2007, 12h56

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