Spring 2022 Jpa

Télécharger au format pdf ou txt
Télécharger au format pdf ou txt
Vous êtes sur la page 1sur 16

Persistance des données

JPA/Hibernate
Spring Data
1 Présentation
Jakarta Persistence API

• JPA est une abstraction de la couche JDBC, les classes et les annotations JPA sont dans le package
javax.persistance (jakarta.persistence).

• JPA 1.0 a été introduite dans la spécification JAVA EE 5, la spécification Jakarta EE 9 supporte la version
JPA 3.0

• Composants:
– ORM: mécanisme de mapping relationnel objet
– L’API Entity Manager qui gère les opérations CRUD
– JPQL : langage de requête orienté objet.
– JTA (Jakarta Transaction API ) : Mécanisme de gestion des verrouillages et des transactions dans un
environnement concurrent

• Frameworks de persistance JPA


– TopLink
– EclipseLink ( framework de référence JPA, basé sur TopLink).
– Hibernate.
2- Entity

– Une classe Entité est un Javabean annoté par


@Entity
– Annotations
• L’annotation @Table permet de modifier le nom
par défaut de la table associée à l’entité
@Table(name=" Tlivre").
• @Column: pour personnaliser les attributs (par
défaut le nom d’un champ dans la table est
identique au nom de l’attribut)
4- Exemple

package spring.cours.jpa.model;
public void setId(int id) {
import javax.persistence.Entity; this.id = id;
import javax.persistence.Id; }

@Entity public String getNom() {


public class Utilisateur { return nom;
@Id }
private int id;
private String nom; public void setNom(String nom) {
this.nom = nom;
public int getId() { }
return id;
} }
5- Propriétés des colonnes

• @Column permet de déterminer les propriétés d’une colonne dans la table associée.
• Principales propriétés de l’annotation column :
Propriété Valeur par défaut
name Nom de l’attribut
nullable True
Length (String) 255
unique False
@Entity
@Table(name="users")
public class Utilisateur {
@Id
private int id;
@Column(nullable = false, name = "username", length = 60)
private String nom;
@Column(unique = true)
private String email;
// get, set
}
6- Auto incrément

L’annotation GeneratedValue permet de créer une clé primaire auto incrément.


– @GeneratedValue
– @GeneratedValue(strategy=GenerationType.AUTO): le
framework choisit la strégie adaptée selon le
gestionnaire de base de données utilisé.
– @GeneratedValue(strategy = GenerationType.IDENTITY):
type identity.
– @GeneratedValue(strategy = GenerationType.SEQUENCE):
crée une séquence.
– @GeneratedValue(strategy = GenerationType.TABLE): crée
une table pour conserver la dernière valeur utilisée.
7- Héritage

• La JPA supporte trois stratégies de génération


d’une relation d’héritage:
– Une seule table (SINGLE_TABLE:valeur par défaut).
– Une table par classe (JOINED).
– Une table par sous classe (TABLE_PER_CLASS).
• L’annotation @Inheritance est appliquée sur la
classe de base.
Exemple 1: une seule table
@Entity @Entity @Entity
@Inheritance public class ClientImportant public class ClientRegulier extends
public class Client { extends Client { Client {
@Id
@GeneratedValue private double solde; private String adresse;
private long id; … …
private String nom; } }

}

Le champ DTYPE contient le type de client (la valeur


de ce champ contient par défaut le nom de la classe).

@Entity @Entity @Entity

@Inheritance(strategy = @DiscriminatorValue(value="ClientImportant") @DiscriminatorValue(value


InheritanceType.SINGLE_TABLE) = "ClientRegulier")
public class ClientImportant
@DiscriminatorColumn(name = "DTYPE", public class
discriminatorType = DiscriminatorType.STRING) extends Client { ClientRegulier extends
… Client {
@DiscriminatorValue(value = "Client")
} …
public class Client {
}

}
Exemple 2: Une table par classe
Exemple 3: Joined
Hibernate DDL
La propriété spring.jpa.hibernate.ddl-auto
définit le mode de génération de la base de
données par Hibernate, valeurs:
– create
– create-drop: à chaque démarrage la base de
données est créée puis supprimée.
– update : mise du schéma de la base de
données (si c’est possibe)
– none : valeur par défaut (à utiliser en
production).
Associations
La spécification JPA supporte trois types d’association :
One to one
Many to one / One to Many
Many to Many

Les trois types d’association peuvent être unidirectionnelles (navigables dans un sens)
ou bidirectionnelles (navigables dans les deux sens), la navigabilité impacte l’utilisation
des classes dans le programme et non pas les tables générées dans la base de
données.
@ManyToOne

L’association ManyToOne est la plus utilisée dans la pratique, dans la classe Produit on
ajoutera un attribut de type Categorie.
Categorie Produit
@Entity @Entity

public class Categorie { public class Produit {

@Id @Id
@GeneratedValue(strategy=GenerationType
@GeneratedValue(strategy = .IDENTITY)
GenerationType.IDENTITY)
private long reference;
private long catId;
private String designation;
private String libelle;
private double prix;

@ManyToOne

private Categorie categorie;


}

}
@OneToMany
Navigabilité : Catalogue  Produit

Catalogue
@Entity
Par défaut l’annotation ManyToOne génère une table
public class Catalogue {
association ( ce qui est souhaité dans notre exemple
@Id

@GeneratedValue(strategy =
) , pour généré une clé étrangère dans la table
GenerationType.IDENTITY) Produit, il faut ajouter l’annotation JoinColumn pour
private long id; définir le nom de la clé étrangère dans la table
private String titre;
produit :
@OneToMany

private List<Produit>
produits=new ArrayList<>();

…}
ManyToMany
•la navigabilité Produit  Magasin
@ManyToMany(mappedBy = "produits")
private List<Magasin> magasins=new ArrayList<>();
Ce qui permettra d’accéder aux magasins à partir d’un produit p.getMagasins()
JPQL
Exemple de requêtes:

•SELECT li From Livre li


•SELECT li From Livre li Where li.titre='UML'
•SELECT li.titre, li.Editeur from livre li
JPQL ( Java Persistence Query Language) est un •SELECT c.Adresse.pays from client c
langage d’interrogation orienté objet similaire
au langage SQL, Syntaxe d'une requête:
Structure d’une requête •SELECT
•FROM
•[WHERE ]
•[ORDER BY ]
•[GROUP BY ]
•[HAVING ]

Sélection selon une condition (JPA 2.0)

•SELECT CASE l.editeur WHEN 'Eyrolles"


•THEN l.prix * 0.5
•ELSE l.prix * 0.8
•END
•FROM Livre l
SQL JPQL

SELECT * SELECT p
FROM produit FROM Produit p
WHERE prix > 100 WHERE p.prix > 100
ORDER BY designation; ORDER BY p.designation

Vous aimerez peut-être aussi