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

JDBC Java Discussion :

Problème condition WHERE


Sujet :

JDBC Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre habitué
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2012
    Messages
    9
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

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

    Informations forums :
    Inscription : Juin 2012
    Messages : 9
    Par défaut Problème condition WHERE
    Bonjour tout le monde

    J'ai une question assez simple :

    Soit une Table 'lol' contenant un champ 'checked' de type TINYINT (0 par défaut),
    Soit 'lol' contenant 10 lignes avec une valeur 'checked' de 1, et 20 autres lignes avec une valeur 'checked' de 0,

    Je n'arrive pas à trouver le nombre de lignes ou la valeur de 'checked' est différent de 0 (le résultat serait égal à 10) :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    result = state.executeQuery("SELECT COUNT(*) FROM lol WHERE 'lol.checked'!=0;");
    if(result.next()){nbunchecked = result.getInt(1); System.out.println("> "+nbunchecked); }
    Cette requête renvoie toujours 0.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    result = state.executeQuery("SELECT COUNT(*) FROM lol WHERE 'lol.checked'=0;");
    if(result.next()){nbunchecked = result.getInt(1); System.out.println("> "+nbunchecked); }
    Cette requête renvoie toujours 30.

    Une idée ?
    Merci

  2. #2
    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
    Par défaut
    Bonjour,

    1- Vire le ";" dans la requête.
    2- Ne met pas le nom de la colonne dans les singles quote ' car ça sera évalué comme une valeur. Utilise ` ou ne met rien.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     state.executeQuery("SELECT COUNT(*) FROM lol WHERE `lol.checked` !=0 ");
    A+.

  3. #3
    Expert éminent
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 482
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 482
    Par défaut
    Citation Envoyé par andry.aime Voir le message
    Utilise `
    C'est standard ça? Parce que, pour protéger des noms de colonne, j'ai toujours utilisé la double quote moi ("lol.checked")

    Attention aussi que, suivant le SGDB, quand tu met entre quotes un nom de colonne, il deviens "case sensitive" alors que quand il a été créé il a probablement été créé en uppercase par défaut, donc ça deviendrais

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     state.executeQuery("SELECT COUNT(*) FROM lol WHERE `lol.CHECKED` !=0 ");

  4. #4
    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
    Par défaut
    Citation Envoyé par tchize_ Voir le message
    C'est standard ça?
    Bien vu, je crois que c'est seulement pour MySql, et pour SqlServer c'est [nom de colonne]. Le standard c'est le double quote. Mais je ne vois pas trop l’intérêt de l'utiliser si on utilise pas un mot réservé comme nom de colonne ou table et c'est le genre de chose que l'on doit éviter.

    A+.

  5. #5
    Expert éminent
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 482
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 482
    Par défaut
    bha, la commande

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    create table "drop database;" ("delete * from *" varchar2(1))
    ça fait toujours plaisir à l'administrateur

  6. #6
    Membre habitué
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2012
    Messages
    9
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

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

    Informations forums :
    Inscription : Juin 2012
    Messages : 9
    Par défaut OK
    Merci andry.aime et tchize_ pour vos réponses précises
    Désolé de répondre tardivement (10h de décalage horaire) ^^

    En effet, le remplacement de ' ' par ` ` fonctionne :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    state.executeQuery("SELECT COUNT(*) FROM imagesinformations WHERE `checked`=1");
    PS: avec ou sans le point virgule final


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    create table "drop database;" ("delete * from *" varchar2(1))
    ça fait toujours plaisir à l'administrateur
    ça dépend de l'administrateur ....

    Bonne continuation

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

Discussions similaires

  1. Problème avec condition WHERE dans commande SELECT
    Par Badouba76 dans le forum Objective-C
    Réponses: 3
    Dernier message: 08/11/2013, 18h19
  2. Problème requête SELECT condition WHERE string
    Par Glherbier dans le forum VBA Access
    Réponses: 3
    Dernier message: 27/10/2010, 18h43
  3. [MySQL] Condition where qui me pose problème
    Par Ikaly dans le forum PHP & Base de données
    Réponses: 6
    Dernier message: 27/05/2010, 10h09
  4. Réponses: 7
    Dernier message: 24/06/2008, 16h31
  5. Problème clause WHERE
    Par Invité dans le forum Langage SQL
    Réponses: 3
    Dernier message: 11/06/2004, 15h07

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