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

Langage SQL Discussion :

Problème requête insert where not exists


Sujet :

Langage SQL

  1. #1
    Membre régulier
    Femme Profil pro
    Étudiant
    Inscrit en
    Avril 2013
    Messages
    286
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Avril 2013
    Messages : 286
    Points : 76
    Points
    76
    Par défaut Problème requête insert where not exists
    Bonjour
    çà fait 3 jours que je me casse avec une requette sql java
    mais rien n'est marché
    bon j'ai une table sql avec 7 colonnes alors je veux juste ajouter 5
    j'ai posté çà fait 2 jours le problème ici ais vous m'avez dit que ton problème au niveau java
    alors que le forum java me dit non c'est du jdbc
    Bon à chaque exécution du programme les données se répétent
    c'est pou celà je veux utiliser le INSERT WHERE NOT EXISTS
    pour ne pas voir du répétition
    voilà mon code:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    stmt.executeUpdate("INSERT INTO tout\n" +
                        "SELECT DISTINCT '"+srv.getvlan().intValue()+"','"+srv.getdesc()+"','"+srv.getjr()+"','"+srv.getvrf()+"','"+srv.getaddress()+"' \n" +
                        "FROM dual\n" +
                        "WHERE NOT EXISTS (SELECT * FROM tout WHERE `VLAN` = '"+srv.getvlan()+"' )");
    Il m'affiche l'erreur:
    java.sql.SQLException: Column count doesn't match value count at row 1

  2. #2
    Expert confirmé
    Homme Profil pro
    Inscrit en
    Mai 2002
    Messages
    3 173
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Mai 2002
    Messages : 3 173
    Points : 5 345
    Points
    5 345
    Par défaut
    bonjour,


    cette erreur veut dire que vous n'avez pas le bon nombre de colonne dans la sous-requete qu ifait la selection par rapport au nombre de colonne de la table cible.

    rajoutez les nom des colonnes, par exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    INSERT INTO MA_TABLE (COL_1, COL_2) 
    SELECT COL_1, COL_2
    FROM UNE_AUTRE_TABLE

  3. #3
    Membre régulier
    Femme Profil pro
    Étudiant
    Inscrit en
    Avril 2013
    Messages
    286
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Avril 2013
    Messages : 286
    Points : 76
    Points
    76
    Par défaut
    Voilà
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    stmt.executeUpdate("INSERT INTO tout(VLAN,client,JR,vrf,address)\n" +
    "SELECT DISTINCT '"+srv.getvlan()+"','"+srv.getdesc()+"','"+srv.getjr()+"','"+srv.getvrf()+"','"+srv.getaddress()+"' \n" +
    "FROM dual\n" +
     "WHERE NOT EXISTS (SELECT VLAN FROM tout WHERE `VLAN` = '"+srv.getvlan()+"' )");
    Mais il me donne cette erreur

    com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: 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 '','null','null','172.16.2.159 '
    FROM dual
    WHERE NOT EXISTS (SELECT VLAN FROM to' at line 2

  4. #4
    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 780
    Points
    30 780
    Par défaut
    1. Le DISTINCT est inutile puisqu'il n'y a qu'une ligne de données.
    2. La pseudo-table DUAL existe dans MySQL ? je croyais qu'elle était propre à Oracle.
    3. Pour vérifier la syntaxe d'une requête créée dynamiquement, la meilleure méthode est de l'afficher et de tester le texte préparé dans un interpréteur SQL
    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.

  5. #5
    Membre régulier
    Femme Profil pro
    Étudiant
    Inscrit en
    Avril 2013
    Messages
    286
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Avril 2013
    Messages : 286
    Points : 76
    Points
    76
    Par défaut
    NON mais parce que vous avez suggéré de faire comme ceci:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    INSERT INTO MA_TABLE (COL_1, COL_2) 
    SELECT COL_1, COL_2
    FROM UNE_AUTRE_TABLE

  6. #6
    Membre régulier
    Femme Profil pro
    Étudiant
    Inscrit en
    Avril 2013
    Messages
    286
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Avril 2013
    Messages : 286
    Points : 76
    Points
    76
    Par défaut
    Bon j'ai essayé de faire la requette sur mysql et çà marche elle n'ajoute pas mais c'est quoi le problème au niveau du code?!!!!

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    INSERT INTO tout(VLAN,client,JR,vrf,address)
    SELECT DISTINCT 20,'BLRgmt_SW','','blrgmt','10.41.1.19' 
    FROM dual
    WHERE NOT EXISTS (SELECT VLAN FROM tout WHERE `VLAN` = 20) ;

  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 780
    Points
    30 780
    Par défaut
    Il faut décomposer le problème alors.

    Que retourne cette requête ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT VLAN FROM tout WHERE `VLAN` = 20
    Et celle-ci ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    SELECT DISTINCT 20,'BLRgmt_SW','','blrgmt','10.41.1.19' 
    FROM dual
    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.

  8. #8
    Membre régulier
    Femme Profil pro
    Étudiant
    Inscrit en
    Avril 2013
    Messages
    286
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Avril 2013
    Messages : 286
    Points : 76
    Points
    76
    Par défaut
    je l'ai testé sur SQL a premier m'affiche 20 c'est juste
    La 2ème affiche 2 lignes contenant les mêmes données de VLAN=20

  9. #9
    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 780
    Points
    30 780
    Par défaut
    Pourquoi deux lignes ?
    La table DUAL ne doit contenir qu'une ligne !
    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.

  10. #10
    Membre régulier
    Femme Profil pro
    Étudiant
    Inscrit en
    Avril 2013
    Messages
    286
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Avril 2013
    Messages : 286
    Points : 76
    Points
    76
    Par défaut
    elle m'a donné 2 lignes je sais pas pourquoi

  11. #11
    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 780
    Points
    30 780
    Par défaut
    Et avec celle-là, tu as toujours 2 lignes ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    SELECT 20 VLAN, 'BLRgmt_SW' client, '' JR,'blrgmt' vrf,'10.41.1.19' address
    FROM dual
    As-tu affiché la requête préparée par ton programme avant qu'il l'exécute ?
    Correspond-elle bien à ce que tu attends ?
    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.

  12. #12
    Membre régulier
    Femme Profil pro
    Étudiant
    Inscrit en
    Avril 2013
    Messages
    286
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Avril 2013
    Messages : 286
    Points : 76
    Points
    76
    Par défaut
    NON juste une ligne

  13. #13
    Membre régulier
    Femme Profil pro
    Étudiant
    Inscrit en
    Avril 2013
    Messages
    286
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Avril 2013
    Messages : 286
    Points : 76
    Points
    76
    Par défaut
    j'ai essayé d'entrer des données existent sur la table SQL dans le code de la requette et çà marche ils ne sont pas ajoutés

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    stmt.executeUpdate("INSERT INTO tout(VLAN,client,JR,vrf,address)\n" +
    "SELECT DISTINCT 20,'BLRMgmt_SW','','blrmgmt','10.81.1.19' \n" +
    "FROM dual\n" +
     "WHERE NOT EXISTS (SELECT VLAN FROM tout WHERE `VLAN` = 20 )");
    Mais lorsque je fait les paramètres ile me donne cette Erreur:

    com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: 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 '','','','172.16.2.159 '
    FROM dual
    WHERE NOT EXISTS (SELECT VLAN FROM tout WHERE' at line 2

  14. #14
    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 780
    Points
    30 780
    Par défaut
    Citation Envoyé par al1_24 Voir le message
    As-tu affiché la requête préparée par ton programme avant qu'il l'exécute ?
    Correspond-elle bien à ce que tu attends ?
    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.

  15. #15
    Membre régulier
    Femme Profil pro
    Étudiant
    Inscrit en
    Avril 2013
    Messages
    286
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Avril 2013
    Messages : 286
    Points : 76
    Points
    76
    Par défaut
    Mais j'ai déjà posté la requette pas mal de fois

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    stmt.executeUpdate("INSERT INTO tout(VLAN,client,JR,vrf,address)\n" +
    "SELECT DISTINCT '"+srv.getvlan()+"','"+srv.getdesc()+"','"+srv.getjr()+"','"+srv.getvrf()+"','"+srv.getaddress()+"' \n" +
    "FROM dual\n" +
     "WHERE NOT EXISTS (SELECT VLAN FROM tout WHERE `VLAN` = '"+srv.getvlan()+"' )");

  16. #16
    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 780
    Points
    30 780
    Par défaut
    Ce n'est pas ton programme qui est intéressant mais ce qu'il fait.
    Essaye quelque chose de ce style (je ne pratique pas java)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    variable := "INSERT INTO tout(VLAN,client,JR,vrf,address)\n" +
    "SELECT DISTINCT '"+srv.getvlan()+"','"+srv.getdesc()+"','"+srv.getjr()+"','"+srv.getvrf()+"','"+srv.getaddress()+"' \n" +
    "FROM dual\n" +
     "WHERE NOT EXISTS (SELECT VLAN FROM tout WHERE `VLAN` = '"+srv.getvlan()+"' )";
    print variable;
    stmt.executeUpdate(variable);
    Est-ce que c'est bien la requête que tu t'attends à exécuter qui est affichée ?
    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.

  17. #17
    Membre régulier
    Femme Profil pro
    Étudiant
    Inscrit en
    Avril 2013
    Messages
    286
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Avril 2013
    Messages : 286
    Points : 76
    Points
    76
    Par défaut
    désolé mais j'ai pas compris pourquoi comment stocker résultat Insert dans une variable ??

  18. #18
    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 780
    Points
    30 780
    Par défaut
    Ce n'est pas le résultat de l'insert, c'est le texte de la requête qu'il faudrait afficher.
    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.

  19. #19
    Membre régulier
    Femme Profil pro
    Étudiant
    Inscrit en
    Avril 2013
    Messages
    286
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Avril 2013
    Messages : 286
    Points : 76
    Points
    76
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    INSERT INTO tout(VLAN,client,JR,vrf,address)
    SELECT DISTINCT '20',' BLRMgmt_SW
    ','null','blrmgmt','10.81.1.19' 
    FROM dual
    WHERE NOT EXISTS (SELECT VLAN FROM tout WHERE `VLAN` = '20' )
    Pour la 1ère donnée et c'est la même chose pour les autres
    juste une donnée il m'a affiché çà:

    SELECT DISTINCT '728',' Bs_TM139676
    ','13966
    ','null','172.36.2.149 '
    FROM dual
    at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:57)
    at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)
    t java.lang.reflect.Constructor.newInstance(Constructor.java:525)
    at com.mysql.jdbc.Util.handleNewInstance(Util.java:411)
    at com.mysql.jdbc.Util.getInstance(Util.java:386)

  20. #20
    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 780
    Points
    30 780
    Par défaut
    Et si tu exécutes cette requête telle qu'elle apparait ici dans ton interpréteur SQL, elle passe ? Avec le saut de ligne dans la chaine client ?
    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.

Discussions similaires

  1. Insert where not exists
    Par cisco.nat dans le forum Général Java
    Réponses: 4
    Dernier message: 28/06/2013, 11h46
  2. Insert where not exists from array<Class.java>
    Par cisco.nat dans le forum Langage SQL
    Réponses: 4
    Dernier message: 24/06/2013, 23h42
  3. [MySQL-5.5] comment faire un insert en bloc where not exists
    Par Motti2 dans le forum Requêtes
    Réponses: 0
    Dernier message: 26/05/2013, 13h42
  4. REQUETE INSERT WHERE NOT EXISTS
    Par tidou95220 dans le forum Langage SQL
    Réponses: 1
    Dernier message: 27/03/2012, 13h35
  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