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

Persistance des données Java Discussion :

Java SQL Requête


Sujet :

Persistance des données Java

  1. #1
    Membre du Club
    Inscrit en
    Avril 2009
    Messages
    133
    Détails du profil
    Informations forums :
    Inscription : Avril 2009
    Messages : 133
    Points : 45
    Points
    45
    Par défaut Java SQL Requête
    bonjour, je voudrais verifier si ma requete sql a eu des resultats et par la suite effectuer un traitement

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    ResultSet rs=null;
    rs = statement.executeQuery("SELECT * FROM table WHERE nom ="+nom1+"");
     
    if (rs == null)
    retour=0;
    else retour=1;
    le probleme c'est que retour se met toujours à 1 meme si il y'a pas de nom1 correspondant a la requete dans ma base de donnnées !

    je voudrais trouver comment trouver si cette requete retourne des resultats ou non j'ai essayé avec count mais je n'ai pas su

    mci

  2. #2
    Rédacteur
    Avatar de longbeach
    Profil pro
    Architecte de système d’information
    Inscrit en
    Avril 2003
    Messages
    943
    Détails du profil
    Informations personnelles :
    Âge : 49
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Architecte de système d’information

    Informations forums :
    Inscription : Avril 2003
    Messages : 943
    Points : 2 370
    Points
    2 370
    Par défaut
    Suffit de regarder ce que retourne la méthode :

    http://download.oracle.com/javase/1....lang.String%29

    ça ne retourne jamais null.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Returns:
        either the row count for INSERT, UPDATE or DELETE statements, or 0 for SQL statements that return nothing

  3. #3
    Membre chevronné
    Inscrit en
    Mai 2006
    Messages
    1 364
    Détails du profil
    Informations forums :
    Inscription : Mai 2006
    Messages : 1 364
    Points : 1 984
    Points
    1 984
    Par défaut
    salut,

    Pour tester si la requete ne renvoie rien, il faut faire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    if (rs.next() == false)
    {
       // La requete ne renvoie rien
    }

  4. #4
    Membre du Club
    Inscrit en
    Avril 2009
    Messages
    133
    Détails du profil
    Informations forums :
    Inscription : Avril 2009
    Messages : 133
    Points : 45
    Points
    45
    Par défaut
    Citation Envoyé par hwoarang Voir le message
    salut,

    Pour tester si la requete ne renvoie rien, il faut faire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    if (rs.next() == false)
    {
       // La requete ne renvoie rien
    }
    merci , ça marche tres bien

  5. #5
    Modérateur

    Homme Profil pro
    Développeur java, access, sql server
    Inscrit en
    Octobre 2005
    Messages
    2 710
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Développeur java, access, sql server
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2005
    Messages : 2 710
    Points : 4 794
    Points
    4 794
    Par défaut
    Je vais pinailler sur la performance, mais la syntaxe de ta requête
    fait penser que tu examines plusieurs tables pour savoir si elles sont vides ou non.

    Si la table n'est pas vide et qu'elle comporte beaucoup d'enregistrements,
    cela peut prendre du temps.

    Essayes avec :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    rs = statement.executeQuery("SELECT COUNT(*) As NB FROM table WHERE nom ="+nom1+"");
    Cette requête te renvoie toujours le nombre d'enregistrements sans les parcourir.
    Il te suffit d'examiner le contenu du champ NB qui sera à 0 si la table est vide ou > 0 si la table a des enregistrements.
    Labor improbus omnia vincit un travail acharné vient à bout de tout - Ambroise Paré (1510-1590)

    Consulter sans modération la FAQ ainsi que les bons ouvrages : http://jmdoudoux.developpez.com/cours/developpons/java/

  6. #6
    Membre du Club
    Inscrit en
    Avril 2009
    Messages
    133
    Détails du profil
    Informations forums :
    Inscription : Avril 2009
    Messages : 133
    Points : 45
    Points
    45
    Par défaut
    Citation Envoyé par Népomucène Voir le message
    Je vais pinailler sur la performance, mais la syntaxe de ta requête
    fait penser que tu examines plusieurs tables pour savoir si elles sont vides ou non.

    Si la table n'est pas vide et qu'elle comporte beaucoup d'enregistrements,
    cela peut prendre du temps.

    Essayes avec :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    rs = statement.executeQuery("SELECT COUNT(*) As NB FROM table WHERE nom ="+nom1+"");
    Cette requête te renvoie toujours le nombre d'enregistrements sans les parcourir.
    Il te suffit d'examiner le contenu du champ NB qui sera à 0 si la table est vide ou > 0 si la table a des enregistrements.
    en effet c'est optimisé
    je te remercie

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

Discussions similaires

  1. Java et requête SQL
    Par Sieldev dans le forum Général Java
    Réponses: 3
    Dernier message: 16/11/2008, 20h34
  2. [PL/SQL]requête imbriquée
    Par Nadine dans le forum Oracle
    Réponses: 6
    Dernier message: 01/02/2005, 16h21
  3. [SQL] Requête à jointure qui ne fonctionne pas
    Par Bensor dans le forum Langage SQL
    Réponses: 2
    Dernier message: 09/12/2004, 16h10
  4. [java.sql.Date] format compatible tout sgbd ?
    Par djskyz dans le forum JDBC
    Réponses: 8
    Dernier message: 15/09/2004, 11h28
  5. [JDBC] java.sql.SQLException: Closed Statement
    Par cmoulin dans le forum JDBC
    Réponses: 4
    Dernier message: 03/09/2004, 17h22

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