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 :

Hibernate + OneToMany : problème de filtre


Sujet :

Hibernate Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Décembre 2004
    Messages
    759
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2004
    Messages : 759
    Par défaut Hibernate + OneToMany : problème de filtre
    Bonjour,

    La base est Sybase, le type de date est datetime.


    Classe Calendrier :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    	@Id
    	@Column(name = "CAL_CODE" )
    	private Integer codeCalendrier;
     
    	@OneToMany(fetch = FetchType.EAGER)
    	@JoinColumn(name = "CAL_CODE")
    	private List<JourFerie> lstJourFerie;
    ...

    Classe JourFerie:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    @EmbeddedId
    	private JourFeriePK pk;
     
    	public static class JourFeriePK implements Serializable {
     
    		@ManyToOne(fetch = FetchType.LAZY)
    		@JoinColumn(name = "CAL_CODE")
    		private Calendrier calendrier;
     
    		@Column(name = "JF_DATE", columnDefinition="datetime")
    		@Temporal(TemporalType.TIMESTAMP)
    		private Date jourFerie;
    ...
    }
    Si je fais du native query, voilà la requête que je veux faire (et qui donne ce que je veux dans un requêteur SQL) :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    select cal.*, jf.* from CALENDRIER cal, JOUR_FERIE jf
    where cal.CAL_CODE *= jf.CAL_CODE 
    and datediff(dd, getDate(), jf.JF_DATE) >= 0
    Rien à faire, ça me sort toutes les dates!
    EDIT : mieux, si je fait datediff(yy, getDate(), jf.JF_DATE) ça ne me sort aucune ligne (alors qu'évidememnt j'en ai en base)

    Merci par avance.

  2. #2
    Membre éclairé
    Profil pro
    Inscrit en
    Décembre 2004
    Messages
    759
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2004
    Messages : 759
    Par défaut
    J'ai essayé de m'inspirer de ça pour faire via les Criteria mais ça ne marche pas...
    http://stackoverflow.com/questions/2...toone-and-list

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    		Criteria crit = sess.createCriteria(Calendrier.class);
    		crit.createAlias("lstJourFerie", "lstJourFerie", CriteriaSpecification.LEFT_JOIN);
    		crit.createAlias("lstJourFerie_jourFerie", "lstJourFerie.jourFerie", CriteriaSpecification.LEFT_JOIN);
    		Date dateDebut = new Date();
    		Date dateFin = DateHelper.addToDate(dateDebut, 365);
    		crit.add(Restrictions.between("lstJourFerie_jourFerie", dateDebut, dateFin));
    		result = crit.list();
    -->org.hibernate.QueryException: could not resolve property: lstJourFerie_jourFerie of: com.his.appli.domain.Calendrier

  3. #3
    Membre éclairé
    Profil pro
    Inscrit en
    Décembre 2004
    Messages
    759
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2004
    Messages : 759
    Par défaut
    Et voilà la solution!

    Classe Calendrier:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    	@Id
    	@Column(name = "CAL_CODE" )
    	private Integer codeCalendrier;
     
    	@OneToMany(fetch = FetchType.EAGER)
    	@JoinColumn(name = "CAL_CODE")
    @Filter(name="filtreJourFerie", condition=" datediff(yy, getDate(), JF_DATE) >= 0 ")
    	private List<JourFerie> lstJourFerie;

    Classe JourFerie:
    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
    @Entity
    @FilterDef(name="filtreJourFerie")
    @Table(name = "JOUR_FERIE")
    public class JourFerie implements Serializable {
    
    	public static class JourFeriePK implements Serializable {
    		
    		@ManyToOne(fetch = FetchType.LAZY)
    		@JoinColumn(name = "CAL_CODE")
    		private Calendrier calendrier;
    
    		@Column(name = "JF_DATE", columnDefinition="datetime")
    		@Temporal(TemporalType.TIMESTAMP)
    		private Date jourFerie;
    ...
    }
    Et dans le DAO :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    org.hibernate.Session sess = ((org.hibernate.Session) myEntityManager.getDelegate());
    sess.enableFilter("filtreJourFerie");		
    Query query = myEntityManager.createQuery("select distinct object(c) from Calendrier c left join fetch c.lstJourFerie ");		
    result = query.getResultList();
    sess.disableFilter("filtreJourFerie");

  4. #4
    Membre éclairé
    Profil pro
    Inscrit en
    Décembre 2004
    Messages
    759
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2004
    Messages : 759
    Par défaut
    Au fait le jour où quelqu'un peut m'expliquer pourquoi ça marchait pas en NativeQuery, ça m'intéressera...

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

Discussions similaires

  1. [Hibernate][Oracle] Problème de rapidité
    Par Saloucious dans le forum Hibernate
    Réponses: 7
    Dernier message: 27/11/2008, 11h00
  2. Problème de filtre dans un formulaire acess
    Par cdbaloo dans le forum Access
    Réponses: 4
    Dernier message: 31/03/2006, 17h25
  3. Problème avec filtre d'un formulaire ?
    Par HookerSeven dans le forum Access
    Réponses: 3
    Dernier message: 25/02/2006, 01h59
  4. Problème de filtre sur un formulaire
    Par bernardmichel dans le forum IHM
    Réponses: 6
    Dernier message: 12/12/2005, 15h36
  5. [Hibernate][Ibatis] Problème de performance..
    Par Saloucious dans le forum Hibernate
    Réponses: 2
    Dernier message: 29/10/2005, 13h21

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