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

Hibernate Java Discussion :

Requête paramétrée ne renvoyant pas de résultats [HQL]


Sujet :

Hibernate Java

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Août 2013
    Messages
    20
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2013
    Messages : 20
    Points : 12
    Points
    12
    Par défaut Requête paramétrée ne renvoyant pas de résultats
    Bonjour,

    Je rencontre un blocage lorsque j'utilise la requête paramétrée :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    session.createQuery("from Entite e where e.name = :param").setParameter("param", variable).list();
    La liste retournée est vide.
    Alors que la requête équivalente sans paramètres :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    session.createQuery("from Entite e where e.name = '" + variable + "'").list();
    renvoie bien une liste avec les valeurs attendues.

    Avez-vous une idée d'où peut venir cette différence ?

  2. #2
    Membre chevronné Avatar de jeffray03
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juillet 2008
    Messages
    1 501
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Allemagne

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Juillet 2008
    Messages : 1 501
    Points : 2 120
    Points
    2 120
    Par défaut
    salut,
    le parametre est de que type?
    variable est de quel type?

    Eric

  3. #3
    Membre à l'essai
    Profil pro
    Inscrit en
    Août 2013
    Messages
    20
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2013
    Messages : 20
    Points : 12
    Points
    12
    Par défaut
    Bonjour,
    le paramètre est de type String, variable String également.
    J'avais à tout hasard essayé en remplaçant "setParameter" par "setString" sans plus de succès

  4. #4
    Membre chevronné Avatar de jeffray03
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juillet 2008
    Messages
    1 501
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Allemagne

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Juillet 2008
    Messages : 1 501
    Points : 2 120
    Points
    2 120
    Par défaut
    salut,
    as tu essayé?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    session.createQuery("from Entite e where e.name = ? ").setParameter(0 , variable).list();
    Eric

  5. #5
    Membre chevronné
    Avatar de eulbobo
    Homme Profil pro
    Développeur Java
    Inscrit en
    Novembre 2003
    Messages
    786
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur Java

    Informations forums :
    Inscription : Novembre 2003
    Messages : 786
    Points : 1 993
    Points
    1 993
    Par défaut
    EDIT : j'avais pas vu que tu avais testé sans succès le setString
    Le problème doit venir du contenu de ta variable, parce qu'il n'y a pas de raison que ça passe en concatenant ou en utilisant un type paramétré

    Essayes avec ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    session.createQuery("from Entite e where e.name = ?").setString(0, variable).list();
    Et tant qu'à faire, affiche nous le contenu de ta variable comme ça :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    System.out.println(">"+variable+"<");

  6. #6
    Membre à l'essai
    Profil pro
    Inscrit en
    Août 2013
    Messages
    20
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2013
    Messages : 20
    Points : 12
    Points
    12
    Par défaut
    Ah oui, j'avais oublié de préciser que j'avais également essayé la requête avec un paramètre positionnel et non nommé. Sans différence non plus.

    Je regarde pour récupérer le contenu de la variable.
    EDIT : voilà ma variable : >MYUNIT<

  7. #7
    Membre chevronné Avatar de jeffray03
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juillet 2008
    Messages
    1 501
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Allemagne

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Juillet 2008
    Messages : 1 501
    Points : 2 120
    Points
    2 120
    Par défaut
    et tu as dans ta base de données, cette valeur la en tant que name?
    ecrit mot a mot?

  8. #8
    Membre à l'essai
    Profil pro
    Inscrit en
    Août 2013
    Messages
    20
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2013
    Messages : 20
    Points : 12
    Points
    12
    Par défaut
    Alors effectivement, j'ai oublié de préciser que les valeurs en base de données sont type "TEXTE " donc ici "MYUNIT " au lieu de "MYUNIT".
    Ce serait ça la cause ?
    Pourtant le résultat sort bien en requêtant directement la base
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select * from atelier_gmao where unit='MYUNIT';
    et comme je disais précédemment sous la forme
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    session.createQuery("from Entite e where e.name = '" + variable + "'").list();

  9. #9
    Membre chevronné
    Avatar de eulbobo
    Homme Profil pro
    Développeur Java
    Inscrit en
    Novembre 2003
    Messages
    786
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur Java

    Informations forums :
    Inscription : Novembre 2003
    Messages : 786
    Points : 1 993
    Points
    1 993
    Par défaut
    Donnes nous
    - le nom de la base de données que tu utilises
    - ton fichier de mapping pour Entite
    - ta classe pour Entite

    et on aura tout pour te répondre !

  10. #10
    Membre à l'essai
    Profil pro
    Inscrit en
    Août 2013
    Messages
    20
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2013
    Messages : 20
    Points : 12
    Points
    12
    Par défaut
    La base de données est une Oracle 11G

    et voici ma classe (pas de fichier de mapping car j'ai utilisé les annotations)

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    @Entity
    @Table(name = "ENTITE", uniqueConstraints = {
    		@UniqueConstraint(columnNames = "NAME")})
    public class Entite {
    	@Id
            @GenericGenerator(name="generator", strategy="increment")
            @GeneratedValue(generator="generator")
    	@Column(name = "ID_ENTITE", columnDefinition = "number")	
    	private int id_entite;
     
    	@OneToMany(fetch = FetchType.LAZY, mappedBy = "entite")
    	private Set<SousEntite> sous_entites = new HashSet<SousEntite>();
     
    	@ManyToOne(fetch = FetchType.LAZY)
    	@JoinColumn(name = "ID_GOUPE")
    	private Groupe groupe;
     
    	@Column(name = "NAME", columnDefinition = "char", unique = true)	
            private String name;
    }

  11. #11
    Membre chevronné
    Avatar de eulbobo
    Homme Profil pro
    Développeur Java
    Inscrit en
    Novembre 2003
    Messages
    786
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur Java

    Informations forums :
    Inscription : Novembre 2003
    Messages : 786
    Points : 1 993
    Points
    1 993
    Par défaut
    Essayes avec

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    @Column(name = "NAME", columnDefinition = "string", unique = true)	
            private String name;

  12. #12
    Membre à l'essai
    Profil pro
    Inscrit en
    Août 2013
    Messages
    20
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2013
    Messages : 20
    Points : 12
    Points
    12
    Par défaut
    Non, ça ne change rien malheureusement

  13. #13
    Membre chevronné Avatar de jeffray03
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juillet 2008
    Messages
    1 501
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Allemagne

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Juillet 2008
    Messages : 1 501
    Points : 2 120
    Points
    2 120
    Par défaut
    salut,
    peux-tu essayer ceci:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    session.createQuery("from Entite e where e.name like ?").setString(0, variable.replaceAll("\\s", "") + "%").list();
    Eric

  14. #14
    Membre chevronné
    Avatar de eulbobo
    Homme Profil pro
    Développeur Java
    Inscrit en
    Novembre 2003
    Messages
    786
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur Java

    Informations forums :
    Inscription : Novembre 2003
    Messages : 786
    Points : 1 993
    Points
    1 993
    Par défaut
    Et le type de ta colonne c'est quoi précisément? (parce que TEXTE ça me parle pas en Oracle 11)

    jeffray03 : je pense pas que ça marchera vu qu'apparemment il n'y a pas d'espaces avant et après, mais à tester quand même...

  15. #15
    Membre à l'essai
    Profil pro
    Inscrit en
    Août 2013
    Messages
    20
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2013
    Messages : 20
    Points : 12
    Points
    12
    Par défaut
    Bonjour,

    Le type de la colonne est CHAR (100 BYTE). (J'avais écrit "TEXTE<plein d'espaces>" pour l'exemple mais ce n'est pas passé comme je voulais sur le forum)

    Le a bien débloqué le traitement. Mais cela va poser problème si j'ai 2 valeurs commençant pareil dans la base de données non ? (ex : "abcd " et "abce ")

  16. #16
    Membre chevronné
    Avatar de eulbobo
    Homme Profil pro
    Développeur Java
    Inscrit en
    Novembre 2003
    Messages
    786
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur Java

    Informations forums :
    Inscription : Novembre 2003
    Messages : 786
    Points : 1 993
    Points
    1 993
    Par défaut
    Le type CHAR contient toujours des données qui font la longueur totale de ta chaîne, donc dans ton cas, tu dois avoir en base "MYUNIT" suivi de plein d'espaces.
    Du coup, le test d'égalité HQL avec = ne marche pas (il fonctionne avec une requête SQL 'normale' parce que la base de données ne fonctionne pas pareil dans ce cas là : elle n'utilise pas de Statement et fait une conversion des données, les experts Oracle pourront te dire précisément pourquoi).

    Donc deux solutions à ton problème :
    - Déclarer ta colonne en VARCHAR2(100 BYTE)
    - Réécrire ta requête :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    session.createQuery("from Entite e where trim(e.name) = ?").setString(0, variable).list();

    A savoir : le type CHAR n'a que très peu d'intérêt aujourd'hui, autant utiliser un VARCHAR qui te permettra de ne pas utiliser de la place pour stocker des espaces.

  17. #17
    Membre chevronné
    Avatar de eulbobo
    Homme Profil pro
    Développeur Java
    Inscrit en
    Novembre 2003
    Messages
    786
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur Java

    Informations forums :
    Inscription : Novembre 2003
    Messages : 786
    Points : 1 993
    Points
    1 993
    Par défaut
    Point culture sur la comparaison des types CHAR :

    http://docs.oracle.com/cd/A97630_01/...624/b_char.htm

    ANSI/ISO SQL requires that two character values being compared have equal lengths. So, if both values in a comparison have datatype CHAR, blank-padding semantics are used. That is, before comparing character values of unequal length, PL/SQL blank-pads the shorter value to the length of the longer value. For example, given the declarations

    last_name1 CHAR(5) := 'BELLO';
    last_name2 CHAR(10) := 'BELLO '; -- note trailing blanks

    the following IF condition is true:

    IF last_name1 = last_name2 THEN ...
    Pour résumer, Oracle pour comparer deux champs à besoin qu'ils fassent la même taille, du coup avant de vérifier l'égalité de deux chaines qui ne font pas la même taille, il augmente la taille de la chaine la plus petite. Ce qui explique pourquoi ça marche en concatenant la valeur de ton champ dans la requête et pas en passant par une requête paramétrée (qui crée un Statement, et pour lequel le type envoyé ne doit pas correspondre à du CHAR)

  18. #18
    Membre à l'essai
    Profil pro
    Inscrit en
    Août 2013
    Messages
    20
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2013
    Messages : 20
    Points : 12
    Points
    12
    Par défaut
    Merci pour ces explications, cela répond bien à toutes mes questions.

    Je n'ai pas la main sur la base de données donc je vais faire avec le trim.


    Merci à tous pour votre aide !

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

Discussions similaires

  1. [PDO] Une requête qui ne retourne pas de résultat
    Par beegees dans le forum PHP & Base de données
    Réponses: 0
    Dernier message: 25/11/2011, 18h18
  2. [Vxi] Ma requête ne me ramène pas de résultat
    Par emmaja dans le forum Designer
    Réponses: 2
    Dernier message: 30/03/2010, 16h07
  3. [MySQL] requête Mysql n'envoie pas le résultat attendu
    Par tvertain dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 20/11/2008, 16h56
  4. Réponses: 2
    Dernier message: 08/10/2008, 14h22
  5. Requete ne renvoyant pas le résultat souhaité
    Par tranzebou dans le forum Requêtes et SQL.
    Réponses: 3
    Dernier message: 06/08/2008, 16h15

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