Vous n'êtes pas connecté. Connexion
|
|
TP4 EJB 2011-2012 : ajout de relations au TP3De $1Table des matières
IntroductionDans ce TP nous allons manipuler les relations. Nous continuons le TP sur les comptes bancaires. Nous allons associer à chaque compte bancaire un historique : une liste d'opérations bancaires, sous la forme d'une relation 1-N. Un compte bancaire aura n opérations reliées. Par exemple : Creation d'un entity bean OperationBancairePremière étape : ajouter au projet un entity bean correspondant à une operation bancaire. Il aura comme attributs
Ne copiez/collez pas ce code intégralement, ommetez l'attribut de type Date, celui-là vous le saisirez à la main : lorsque vous taperez l'attribut de type Date (on vous proposera d'importer java.util.Date), automatiquement, une annotation de code @temporal apparaitra. Oui, les dates sont bien des types spéciaux ! @Entity public class OperationBancaire implements Serializable { private static final long serialVersionUID = 1L; @Id @GeneratedValue(strategy = GenerationType.AUTO) private int id; private String description; @Temporal(javax.persistence.TemporalType.DATE) private Date dateOperation; private int montant; public OperationBancaire() { } public OperationBancaire(String description, int montant) { this.description = description; this.montant = montant; dateOperation = new Date(); } Ajout de la relation dans l'entity bean CompteBancaireIl suffit de taper la ligne correspondant à l'attribut "liste d'opérations bancaires" dans le bean CompteBancaire pour qu'une ampoule jaune vous propose d'insérer une annotation correspondant à une relation @OneToMany. Ne copiez/collez pas le code, tapez le ! Vous compléterez l'annotation avec les attributs concernant le cascading et le chargement :
@Entity public class CompteBancaire implements Serializable { @Id @GeneratedValue(strategy = GenerationType.AUTO) private int id; private String nom; private int solde; @OneToMany(cascade={CascadeType.ALL}, fetch=FetchType.EAGER) private Collection<OperationBancaire> operations = new ArrayList(); public Collection<OperationBancaire> getOperations() { return operations; } public void setOperations(Collection<OperationBancaire> operations) { this.operations = operations; } .... Detruisez les tables existantes, puisque le modèle de données va changer !Pour la suite, détruisez les tables COMPTES_BANCAIRES, etc de votre projet. Il y a un ordre pour les détruire... Note : si vous êtes en drop and create dans votre persistence.xml ce n'est pas la peine de les détruire à la main. Il devrait suffire de redéployer le projet. Vous pouvez deployer le projet et regarder les tables générées qui devraient ressembler à ceci : Modifiez le session bean GestionCompteBancairesAssocier une operation à chaque modification d'un compte...pour qu'il associe une operation bancaire chaque fois qu'un compte est modifié. Voici un exemple dans la méthode de création de compte : public void creerCompte(String nom, int solde) { CompteBancaire c = new CompteBancaire(nom, solde); OperationBancaire op = new OperationBancaire("Création du compte", solde); c.getOperations().add(op); // ici on ajoute la relation persist(c); } A vous de modifier la méthode qui permet de transférer de l'argent. (attention, pas de persist !!!!! Il suffit d'ajouter une opération, cela mettra à jour automatiquement la relation). Modifiez la page JSF qui affiche la liste des comptesObjectif : Pour que chaque compte dans la liste ou dans le tableau propose un lien qui appelle la servlet de contrôle avec une action indiquant que l'on désire afficher l'historique du compte Lorsqu'on clique sur un de ces liens, cela appelle la méthode showDetail du backing bean. Regardez comment on avait fait dans le TP1. Ecriture d'une JSF pour l'affichage de l'historique d'un compteIl reste maitenant à écrire la page JSF qui va se charger d'afficher les détails du compte.
Modalités de rendu de ce TP
|
Powered by MindTouch Deki Open Source Edition v.8.08 |