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 :

Erreur dans une fonction d'insertion


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 Erreur dans une fonction d'insertion
    Bonjour
    j'ai un code pour insérer une donnée variable dans une table aussi variable
    lorsque j'exécute il me donne cette erreur:
    check the manual that corresponds to your MySQL server version for the right syntax to use near ''ci'(address) SELECT DISTINCT '10.80.90.248' FROM dual WHERE NOT EXISTS (SELECT' at
    voilà ma fonction
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    public void requete(Connection conn, String adresse , String vrf) {
            try {
                PreparedStatement pst = conn.prepareStatement("INSERT INTO '"+vrf+"'(address) "
                        + "SELECT DISTINCT '" + adresse + "' FROM dual WHERE NOT EXISTS "
                        + " (SELECT * FROM '"+vrf+"' WHERE address = '" + adresse + "' )");
                pst.executeUpdate();
                System.out.print("Insertion OK \n");
     
            } catch (Exception e) {
                System.out.println("ERROR :" + e.getMessage());
            }
        }
    Merci

  2. #2
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 115
    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 115
    Points : 28 493
    Points
    28 493
    Par défaut
    Pourquoi encadrer le nom de la table cible avec des guillemets ?

    Par ailleurs, dans SELECT DISTINCT constante FROM DUAL, le DISTINCT est totalement inutile ; DUAL ne contient qu'une ligne.

  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
    parce que c'est pas une table constante elle se change

  4. #4
    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 cette requette çà marche bien avant que j'ajoute le nome de la table est variable :
    voilà ce code s’exécute bien
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    public void requete(Connection conn, int v) {
            try {
                PreparedStatement pst_sip = conn.prepareStatement("INSERT INTO tout(VLAN) "
                        + "SELECT DISTINCT " + v + " FROM dual WHERE NOT EXISTS "
                        + " (SELECT * FROM tout WHERE VLAN = " + v + " )");
                pst_sip.executeUpdate();
                System.out.print("Insertion OK \n");
     
            } catch (Exception e) {
                System.out.println("ERROR :" + e.getMessage());
            }
        }
    juste dans cette étape j'ai aussi le nome de la table est variable

  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
    c'est bon çà marche
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    PreparedStatement pst = conn.prepareStatement("INSERT INTO " + vrf + "(address) "
                        + "SELECT DISTINCT '" + adresse + "' FROM dual WHERE NOT EXISTS "
                        + " (SELECT * FROM " + vrf + " WHERE address = '" + adresse + "' )");

  6. #6
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 115
    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 115
    Points : 28 493
    Points
    28 493
    Par défaut
    Pour vérifier la syntaxe d'une requête créée dynamiquement, la meilleure méthode est de l'afficher puis de tester le texte préparé dans un interpréteur SQL.

    Si je remplace les variables vrf et adresse par toto et tutu respectivement, j'obtiens la requête :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    INSERT INTO 'toto'(address) 
    SELECT DISTINCT 'tutu' FROM dual WHERE NOT EXISTS 
    (SELECT * FROM 'toto' WHERE address = 'tutu' )
    Penses-tu que cette requête s'exécute sans erreur dans MySQL (ou n'importe quel SGBD d'ailleurs) ?

    Edit : tu as compris où était l'erreur mais le DISTINCT est toujours inutile.

  7. #7
    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 travaille avec HeidiSql mais çà marche la dernière que je vous ai envoyé
    Merci bien

  8. #8
    Rédacteur/Modérateur
    Avatar de andry.aime
    Homme Profil pro
    Inscrit en
    Septembre 2007
    Messages
    8 391
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Ile Maurice

    Informations forums :
    Inscription : Septembre 2007
    Messages : 8 391
    Points : 15 059
    Points
    15 059
    Par défaut
    Tu ne dois pas passer directement des valeurs dans une requête, tu dois utiliser setString ou set* du preparedStatement.

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

Discussions similaires

  1. erreur dans une fonction
    Par nicerico dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 11/10/2006, 12h02
  2. Trouver l'erreur dans une fonction
    Par Seth77 dans le forum Langage
    Réponses: 4
    Dernier message: 28/06/2006, 17h38
  3. [débutant] erreur dans une fonction
    Par Skizo dans le forum Access
    Réponses: 7
    Dernier message: 18/05/2006, 11h46
  4. Erreur dans une fonction
    Par dark_vidor dans le forum Langage
    Réponses: 6
    Dernier message: 15/01/2006, 11h23
  5. Réponses: 2
    Dernier message: 11/08/2004, 16h01

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