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 :

comment remplir une liste à partir de deux tables (user et role)


Sujet :

Hibernate Java

  1. #1
    Membre du Club
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2008
    Messages
    49
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Maroc

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Avril 2008
    Messages : 49
    Points : 43
    Points
    43
    Par défaut comment remplir une liste à partir de deux tables (user et role)
    salut,
    j'ai 2 tables: user et role, chaque user possede un et un seul role, comment pourai je remplir une liste avec les users et leur role?

  2. #2
    Membre confirmé Avatar de djsnipe
    Inscrit en
    Mai 2008
    Messages
    440
    Détails du profil
    Informations forums :
    Inscription : Mai 2008
    Messages : 440
    Points : 493
    Points
    493
    Par défaut
    Si chaque User possède un et un seul Role, il faut mapper cette relation dans User de type many-to-one. Ensuite, tu pourras extraire le rôle d'un User directement en appelant le getter getRole(). Donc la liste finale sera une liste de User, chaqu'un connaissant son role.

  3. #3
    Membre du Club
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2008
    Messages
    49
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Maroc

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Avril 2008
    Messages : 49
    Points : 43
    Points
    43
    Par défaut un prob avec setter de idRole
    dans la classe user j'ai mis ça:
    .....
    private Integer idRole;

    public Integer getIdRole() {
    return idRole;
    }

    public void setIdRole(Integer idRole) {
    this.idRole = idRole;
    }
    ....

    et dans le fichier user.hbm.xml j'ai mis ça:
    .....
    <many-to-one name="idRole" class="cri.webssh.domain.model.Role" not-null="false" column="idRole"/>

    et dans la classe userDAOImpl j'ai mis ça:
    List<User> U=this.getHibernateTemplate().find("FROM User");

    ms lorske je veux afficher le idRole dans mon displaytag je recois cette erreur:

    org.hibernate.PropertyAccessException: IllegalArgumentException occurred while calling setter of cri.webssh.domain.model.User.idRole

    vous avez une idée svp?
    merci

  4. #4
    Membre confirmé Avatar de djsnipe
    Inscrit en
    Mai 2008
    Messages
    440
    Détails du profil
    Informations forums :
    Inscription : Mai 2008
    Messages : 440
    Points : 493
    Points
    493
    Par défaut
    Il ne faut pas mettre l'id du rôle, mais l'objet role entier

  5. #5
    Membre du Club
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2008
    Messages
    49
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Maroc

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Avril 2008
    Messages : 49
    Points : 43
    Points
    43
    Par défaut
    je dois donc ajouter l'objet Role dans la classe User comme ça:

    private Role role=null;
    avec:
    public Role getRole() {
    return role;
    }

    public void setRole(Role role) {
    this.role = role;
    }

    mais comment afficher le role dans mn displaytag a partir de cet objet role?

  6. #6
    Membre confirmé Avatar de djsnipe
    Inscrit en
    Mai 2008
    Messages
    440
    Détails du profil
    Informations forums :
    Inscription : Mai 2008
    Messages : 440
    Points : 493
    Points
    493
    Par défaut
    Je fait parti de ceux qui n'ont jamais essayé le display:tag, mais je tenterai bien un truc du genre :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    <display:table name="maListeDeUser">
       <display:column property="nomUtilisateur" />
       <display:column property="role.libelleRole" />
    </display:table>

  7. #7
    Membre du Club
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2008
    Messages
    49
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Maroc

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Avril 2008
    Messages : 49
    Points : 43
    Points
    43
    Par défaut ça y est! it works
    dans la classe User:
    ...;
    private Role role;

    public Role getRole() {
    return role;
    }

    public void setRole(Role role) {
    this.role = role;
    }

    dans User.hbm.xml:
    ...
    <many-to-one name="role" class="cri.webssh.domain.model.Role"
    fetch="join" not-null="false" column="idRole" cascade="none" />

    dans la classe UserDAOImpl:
    ...
    public List<User> getUsersList()throws DataAccessException,java.sql.SQLException{

    this.getSession().setFlushMode(FlushMode.AUTO);
    List<User> U=this.getHibernateTemplate().find("FROM User u left join fetch u.role");
    return U;
    }

    et dans le displaytag (comme tu a proposé):
    <display:column property="role.role" />

    merci djsnipe
    @+

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 10/02/2012, 15h22
  2. [MySQL] Remplir une liste à partir d'une table MySQL
    Par missastro dans le forum PHP & Base de données
    Réponses: 25
    Dernier message: 27/08/2008, 17h42
  3. Réponses: 4
    Dernier message: 04/09/2007, 18h54
  4. Réponses: 4
    Dernier message: 04/06/2007, 10h14
  5. remplir une liste à partir d'une liste
    Par LeXo dans le forum Access
    Réponses: 7
    Dernier message: 14/04/2006, 12h29

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