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 :

Criteria : Recherche multicritère


Sujet :

Hibernate Java

  1. #1
    Membre confirmé Avatar de KneXtasY
    Profil pro
    Inscrit en
    Mars 2004
    Messages
    121
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2004
    Messages : 121
    Par défaut Criteria : Recherche multicritère
    Bonjour,

    j'utilise Criteria pour effectuer une recherche multicritère.

    Prenons par exemple 3 classes Client,Adresse,Telephone
    Mon client correspond à plusieurs adresses et plusieurs telephones.

    Le chargement de ces deux collections se fait avec lazy="false".

    properties est une HashMap correspondant aux différents critères et valeurs à rechercher :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    properties.put("Prenom","Jean");
    properties.put("Nom","Dupont");
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    DetachedCriteria criteria = DetachedCriteria.forClass(Client.class); 
    for(String key : properties.keySet())
    	if(properties.get(key) instanceof String)
    		criteria.add(Restrictions.like(key, properties.get(key)));
    	else
    		criteria.add(Restrictions.eq(key, properties.get(key)));
    Comment faire pour que je puisse avoir un critère sur un champs d'un objet d'une de ces collections (d'une de ces adresse et/ou d'un de ces telephones) ?

    Exemple de requête :
    Je veux les gens s'appelant "Jean" ayant une adresse à "Paris" et ayant un Telephone en 06%.

    Sachant qu'un Objet adresse a une propriété Ville et Telephone a une propriété Numero.

    Merci d'avance !

    EDIT : En fait je ne vois pas bien la différence entre FETCH et createAlias

  2. #2
    Membre émérite Avatar de Gardyen
    Homme Profil pro
    Bio informaticien
    Inscrit en
    Août 2005
    Messages
    637
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Bio informaticien

    Informations forums :
    Inscription : Août 2005
    Messages : 637
    Par défaut
    tu crées simplement d'autres criteria

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    DetachedCriteria criteria = DetachedCriteria.forClass(Client.class);
    DetachedCriteria adresses= criteria.createCriteria("Adresses", "a");
    DetachedCriteria telephones= criteria.createCriteria("Telephones", "t");
    cf http://www.hibernate.org/hib_docs/v3/reference/fr/html_single/#querycriteria-assochttp://www.hibernate.org/hib_docs/v3/reference/fr/html_single/#querycriteria-associationsiations

    ensuite soit tu ajoutes un Criterion a la bonne criteria:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    criteria.add(Restrictions.eq("Prenom", "Jean"));
    adresses.add(Restrictions.eq("Ville", "Jean"));
    telephones.add(Restrictions.like("Numero", "06%"));
    soit tu les ajoutes a la principale en utilisant les alias:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    criteria.add(Restrictions.eq("Prenom", "Jean"));
    criteria.add(Restrictions.eq("a.Ville", "Paris"));
    criteria.add(Restrictions.like("t.Numero", "06%"));
    mais dans les 2 cas il te faut connaitre a quelle table/association ta condition se refere

    j'espere que ca t'aidera

  3. #3
    Membre confirmé Avatar de KneXtasY
    Profil pro
    Inscrit en
    Mars 2004
    Messages
    121
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2004
    Messages : 121
    Par défaut
    Merci beaucoup !

    En fait, je ne m'étais jamais servi des Alias avec Criteria.

    J'ai déja eu des recherches à effectuer avec des Collections :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    DetachedCriteria criteria = DetachedCriteria.forClass(Client.class).createCriteria("telephones").add(Restrictions.like("Numero","%"+numero+"%"));
    La, je cherchais a faire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    DetachedCriteria.forClass(Client.class).createCriteria("telephones").createCriteria("adresses");
    Mais j'avais une erreur comme quoi il n'y avait pas d'attribut adresses à la classe Telephone. (Logique)

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

Discussions similaires

  1. Réponses: 1
    Dernier message: 27/12/2011, 14h44
  2. [Criteria] Recherche multicritère via 'Example'.
    Par Invité dans le forum Hibernate
    Réponses: 5
    Dernier message: 05/11/2008, 10h04
  3. Recherche multicritère
    Par Darlay Jean_Louis dans le forum Access
    Réponses: 2
    Dernier message: 26/10/2005, 09h54
  4. Réponses: 2
    Dernier message: 01/10/2005, 18h42
  5. recherche multicritères
    Par onlineduel dans le forum Débuter
    Réponses: 3
    Dernier message: 30/03/2004, 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