Maven 2 + Hibernate 3.2 + Exemple MySQL (annotation)
Note
Cet article est obsolète et certaines informations ne sont plus valides dans le dernier développement d'Hibernate. Vous devriez vous référer à ce dernier tutoriel -Maven 3 + Hibernate 3.6.3 + Oracle 11g Example (Annotation).
Ce didacticiel modifiera lesMaven 2 + Hibernate 3.2 + MySQL Example (XML mapping)précédents et remplacera le fichier de mappage XML Hibernate par le code d'annotation.
Outils et technologies utilisés dans cet article:
-
Maven 2.2.1
-
JDK 1.6.0_13
-
Hibernate 3.2.3.GA
-
MySQL 5.0
1. Créer une infrastructure de projet
Créer une infrastructure de projet enMaven + Hibernate (XML mapping file) + MySQL Example
2. Ajouter un référentiel JBoss
Le référentiel JBoss danspom.xml
est requis pour télécharger la bibliothèque d'annotations Hibernate.
JBoss repository http://repository.jboss.com/maven2/
3. Ajouter une dépendance d'annotation Hibernate
Ajoutez les dépendances hibernate-annotations et hibernate-commons-annotations danspom.xml
.
hibernate-annotations hibernate-annotations 3.3.0.GA hibernate-commons-annotations hibernate-commons-annotations 3.0.0.GA
Fichier: pom.xml
4.0.0 com.example.common HibernateExample jar 1.0-SNAPSHOT HibernateExample http://maven.apache.org JBoss repository http://repository.jboss.com/maven2/ mysql mysql-connector-java 5.1.9 hibernate hibernate3 3.2.3.GA hibernate-annotations hibernate-annotations 3.3.0.GA hibernate-commons-annotations hibernate-commons-annotations 3.0.0.GA dom4j dom4j 1.6.1 commons-logging commons-logging 1.1.1 commons-collections commons-collections 3.2.1 cglib cglib 2.2 javax.transaction jta 1.1
4. Mettre à jour le chemin d'accès aux classes du projet
Exécutez «mvn eclipse:eclipse
» dans l'invite de commande pour télécharger la bibliothèque de dépendances et mettre à jour le chemin de classe du projet Eclipse.
5. Mettre à jour HibernateUtil.java
Mettez à jour «HibernateUtil
» pour utiliser «AnnotationConfiguration» au lieu de «Configuration» pour créer la fabrique de session Hibernate.
Utilise auparavant «Configuration» - Pour le fichier de mappage XML Hibernate
return new Configuration().configure().buildSessionFactory();
Remplacez-le par «AnnotationConfiguration» - Pour la prise en charge des annotations d'hibernation
return new AnnotationConfiguration().configure().buildSessionFactory();
Fichier: HibernateUtil.java
package com.example.persistence; import org.hibernate.SessionFactory; import org.hibernate.cfg.AnnotationConfiguration; public class HibernateUtil { private static final SessionFactory sessionFactory = buildSessionFactory(); private static SessionFactory buildSessionFactory() { try { // Create the SessionFactory from hibernate.cfg.xml return new AnnotationConfiguration().configure().buildSessionFactory(); } catch (Throwable ex) { // Make sure you log the exception, as it might be swallowed System.err.println("Initial SessionFactory creation failed." + ex); throw new ExceptionInInitializerError(ex); } } public static SessionFactory getSessionFactory() { return sessionFactory; } public static void shutdown() { // Close caches and connection pools getSessionFactory().close(); } }
6. Mettre à jour la classe de modèle
Mettez à jour «Stock.java» pour utiliser l'annotation comme suit:
Stock.java
package com.example.common; import javax.persistence.Column; import javax.persistence.Entity; import javax.persistence.GeneratedValue; import static javax.persistence.GenerationType.IDENTITY; import javax.persistence.Id; import javax.persistence.Table; import javax.persistence.UniqueConstraint; @Entity @Table(name = "stock", catalog = "example", uniqueConstraints = { @UniqueConstraint(columnNames = "STOCK_NAME"), @UniqueConstraint(columnNames = "STOCK_CODE") }) public class Stock implements java.io.Serializable { private Integer stockId; private String stockCode; private String stockName; public Stock() { } public Stock(String stockCode, String stockName) { this.stockCode = stockCode; this.stockName = stockName; } @Id @GeneratedValue(strategy = IDENTITY) @Column(name = "STOCK_ID", unique = true, nullable = false) public Integer getStockId() { return this.stockId; } public void setStockId(Integer stockId) { this.stockId = stockId; } @Column(name = "STOCK_CODE", unique = true, nullable = false, length = 10) public String getStockCode() { return this.stockCode; } public void setStockCode(String stockCode) { this.stockCode = stockCode; } @Column(name = "STOCK_NAME", unique = true, nullable = false, length = 20) public String getStockName() { return this.stockName; } public void setStockName(String stockName) { this.stockName = stockName; } }
7. Supprimer le fichier de mappage XML Hibernate existant
Supprimez le fichier de mappage XML Hibernate existant - «Stock.hbm.xml», ce n'est plus nécessaire.
8. Mettre à jour le fichier de configuration Hibernate
Mettez à jour le fichier de configuration Hibernate - hibernate.cfg.xml.
Auparavant, il avait le fichier de mappage XML Hibernate avec la balise «ressource de mappage»
Changez-le en classe de modèle avec la balise «mapping class»
Fichier: hibernate.cfg.xml
false com.mysql.jdbc.Driver password jdbc:mysql://localhost:3306/example root org.hibernate.dialect.MySQLDialect true
9. Revoir la structure du projet
Il semble que peu de fichiers aient été modifiés, vérifiez-le et assurez-vous que la structure des dossiers est la suivante:
10. Exécutez-le et voyez la sortie
Exécutez votre App.java, il insérera un nouvel enregistrement dans la table "Stock". Le résultat doit être identique à l'exemple de fichier de mappage XML Hibernate précédent.
Maven + Hibernate + MySQL ... Hibernate: insert into example.stock (STOCK_CODE, STOCK_NAME) values (?, ?)
Terminé.
Téléchargez-le -Maven-Hibernate-annotation-MySQL-Example.zip (8 Ko)