etudiant
, mot de passe etudiant
Ceci est une ancienne révision du document !
Ce TP est à rendre pour le dimanche 28/09/2014.
On déposera une archive zip sur spiral:
Grp-Nom1-Numero1-Nom2-Numero2.zip
où:.zip
, .tar.gz
ou .7z
. Aucun autre format ne sera accepté.etudiants.properties
dont le contenu sera une mise à jour du suivant: groupe=X nom1=aaaaaa prenom1=bbbbbb numero1=1234567 nom2=cccccc prenom2=dddddd numero2=2345678
Le TP sera évalué sur le fonctionnement du mapping et sur la cohérence du modèle objet, mais surtout sur les commentaires qui viendront expliciter ces éléments. En particulier chaque occurrence de chaque annotation devra être commentée afin d'indiquer sa signification.
Le non respect des consignes de rendu entrainera une sanction sur la note du TP.
L'objectif de ce TP est de mettre en place un mapping Objet/Relationnel via l'API JPA.
Quelques liens:
javax.persistence
Maven est un utilitaire de compilation/exécution/test de projet Java qui sera utilisé dans le cadre des TP de l'UE. Configurer Maven comme indiqué dans l'aide.
Télécharger et décompresser le projet de base: mif18-2014-base.zip, ou mieux le cloner depuis la forge:
hg clone https://forge.univ-lyon1.fr/hg/inf1008m-2014-base mif18-2014-base
Un projet Maven possède deux répertoires de sources: src/main et src/test. Le premier contient les classes “métier” alors que le second ne contient que le code de test.
Dans Eclipse, il faut importer le projet en utilisant Import existing maven project
. Le projet peut être directement ou vert dans Netbeans. Il est également possible d'utiliser IntelliJ en important le projet et en spécifiant d'utiliser un type de projet maven à l'import.
<note warning>Le projet à utiliser est le projet orm-2014, disponible soit directement, soit le cas échéant dans les modules du projet ouvert</note>
<note tip>Il est possible d'utiliser la ligne de commande plutot que l'IDE. Pour compiler et tester le mapping depuis le répertoire orm-2014
, faire:
mvn test
</note>
Le fichier pom.xml
contient les dépendances sur les bibliothèques nécessaires au TP.
Le fichier src/main/resources/META-INF/persistence.xml
contient les informations pour mettre en place le cadre de persistance.
Le fichier orm-2014/initialisation-pg.sql
du projet embryonnaire permet de mettre en place le schéma relationnel avec quelques données dans la base PostgreSQL1).
CREATE TABLE cinema( nom VARCHAR(255) PRIMARY KEY, adresse VARCHAR(255) ); CREATE TABLE salle( nom VARCHAR(30) , cinema VARCHAR(255) REFERENCES cinema(nom), capacite INTEGER , PRIMARY KEY(cinema,nom) ); CREATE TABLE seance( debut TIMESTAMP, fin TIMESTAMP, salle VARCHAR(30), cinema VARCHAR(255), film VARCHAR(255), FOREIGN KEY (cinema,salle) REFERENCES salle(cinema,nom), PRIMARY KEY(cinema,salle,debut) ); CREATE TABLE client( num_client INTEGER PRIMARY KEY, nom VARCHAR(255)); CREATE TABLE reservation( id INTEGER PRIMARY KEY, seance TIMESTAMP, salle VARCHAR(30) , cinema VARCHAR(255) , quantite INTEGER , client INTEGER REFERENCES client(num_client), FOREIGN KEY (cinema,salle,seance) REFERENCES seance(cinema,salle,debut)); CREATE SEQUENCE hibernate_sequence INCREMENT 1 MINVALUE 1 MAXVALUE 9223372036854775807 START 1 CACHE 1;
javax.persistence
, afin d'établir les liens entre le modèle relationnel et votre modèle objet.
Le mapping relationnel objet peut être tester à travers le TestCase JUnit placé dans src/test/java/mif18/orm/MappingTest.java
.
Cette classe est exécutable directement comme test JUnit dans Eclipse, Netbeans ou IntelliJ.
@EmbeddedId
, @Embbedable
. Voir également @ElementCollection
si les éléments de la collection ne sont pas des entités.hibernate.hbm2ddl.auto
de validate
à update
permet au framework de modifier le schéma relationnel. Cela peut être utile pour comprendre à quoi correspond le mapping en cours de développement, mais cela écrase le schéma de l'énoncé. A la fin du TP, le mapping doit fonctionner avec le schéma de fourni plus haut. En cas d'impossibilité, justifier les différences dans des commentaires appropriés dans les classes Java.int
ou String
pour les champs qui sont des clés étrangères. Ces champ seront remplacés par des champs désignant des classes du modèle le moment venu (par exemple un champ String cinema
pourra plus tard être remplacé par un champ Cinema cinema
etudiant
, mot de passe etudiant