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 :

complexe requête par criteria


Sujet :

Hibernate Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre très actif Avatar de yacine.dev
    Inscrit en
    Octobre 2009
    Messages
    177
    Détails du profil
    Informations personnelles :
    Âge : 37

    Informations forums :
    Inscription : Octobre 2009
    Messages : 177
    Par défaut complexe requête par criteria
    Bonsoir ,

    Avec plusieurs createcriteria successives comment retrouver l'attribut de la première objet pour y appliquer une restriction ?

    les classes utilisé dans la criteria
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    public class Chanservic implements java.io.Serializable {
     
     
    	private String conteneur;
    	private Set propositionChanservics = new HashSet(0);
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    public class PropositionChanservic implements java.io.Serializable {
     
    	private Long idPropo;
    	private Chanservic chanservic;
    	private Set trPropoChanservics = new HashSet(0);
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    public class TrPropoChanprodui implements java.io.Serializable {
     
    	private Integer id;
    	private PropositionChanprodui propositionChanprodui;
    	private String local;
    voici la requête avec criteria
    :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    List<Chanservic> chanservics=s.createCriteria(Chanservic.class)
    .createCriteria("propositionChanservics")
    .createCriteria("trPropoChanservics")
    .add(Restrictions.or(Restrictions.eq("local", local), Restrictions.ne("je voudrais faire ici une restriction sur la propriéte "conteneur" de la classe Chanservic ?
    si je mets "conteneur" =>erreur (message=trPropoChanservics ne posséde pas la propriété conteneur","select")))
    		.list();
    merci

  2. #2
    Membre très actif Avatar de yacine.dev
    Inscrit en
    Octobre 2009
    Messages
    177
    Détails du profil
    Informations personnelles :
    Âge : 37

    Informations forums :
    Inscription : Octobre 2009
    Messages : 177
    Par défaut
    la solution c'est au lieu de la deuxieme createCriteria il suffit de créer un alias à l'objet

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    List<Chanprodui> chanproduis= s.createCriteria(Chanprodui.class)
    		        .add(Restrictions.eq("produit.codprod", codprod))
    		        .setFetchMode("propositionChanproduis.trPropoChanproduis",FetchMode.JOIN)
    		   
    		        .createAlias("propositionChanproduis", "propos")
    				.createAlias("propos.trPropoChanproduis", "trpropos")
    				.add(Restrictions.or(Restrictions.eq("trpropos.local",local),Restrictions.ne("conteneur", "select")))
    
    				.list();
    A+

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

Discussions similaires

  1. [Hibernate]Traduire une sous requète en criteria?
    Par djodjo dans le forum Hibernate
    Réponses: 2
    Dernier message: 15/06/2006, 13h53
  2. executer une requête par liste déroulante
    Par lolo_bob2 dans le forum Access
    Réponses: 2
    Dernier message: 15/05/2006, 11h35
  3. Modifier une requête par des données différente
    Par leloup84 dans le forum Requêtes
    Réponses: 9
    Dernier message: 06/03/2006, 14h23
  4. IB et Nombre de requêtes par secondes
    Par lio33 dans le forum Débuter
    Réponses: 5
    Dernier message: 15/09/2005, 16h52
  5. Comment grouper une requête par mois ?
    Par Le Pharaon dans le forum Langage SQL
    Réponses: 6
    Dernier message: 29/06/2005, 12h01

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