Hibernate - Fichiers de mappage

Les mappages objet / relationnel sont généralement définis dans un document XML. Ce fichier de mappage indique à Hibernate - comment mapper la ou les classes définies aux tables de la base de données?

Bien que de nombreux utilisateurs d'Hibernate choisissent d'écrire le XML à la main, un certain nombre d'outils existent pour générer le document de mappage. Ceux-ci inclusXDoclet, Middlegen et AndroMDA pour les utilisateurs avancés d'Hibernate.

Considérons notre classe POJO précédemment définie dont les objets persisteront dans la table définie dans la section suivante.

public class Employee {
   private int id;
   private String firstName; 
   private String lastName;   
   private int salary;  

   public Employee() {}
   
   public Employee(String fname, String lname, int salary) {
      this.firstName = fname;
      this.lastName = lname;
      this.salary = salary;
   }
   
   public int getId() {
      return id;
   }
   
   public void setId( int id ) {
      this.id = id;
   }
   
   public String getFirstName() {
      return firstName;
   }
   
   public void setFirstName( String first_name ) {
      this.firstName = first_name;
   }
   
   public String getLastName() {
      return lastName;
   }
   
   public void setLastName( String last_name ) {
      this.lastName = last_name;
   }
   
   public int getSalary() {
      return salary;
   }
   
   public void setSalary( int salary ) {
      this.salary = salary;
   }
}

Il y aurait une table correspondant à chaque objet que vous êtes prêt à fournir de la persistance. Considérez que les objets ci-dessus doivent être stockés et récupérés dans la table SGBDR suivante -

create table EMPLOYEE (
   id INT NOT NULL auto_increment,
   first_name VARCHAR(20) default NULL,
   last_name  VARCHAR(20) default NULL,
   salary     INT  default NULL,
   PRIMARY KEY (id)
);

Sur la base des deux entités ci-dessus, nous pouvons définir le fichier de mappage suivant, qui indique à Hibernate comment mapper la ou les classes définies aux tables de la base de données.

<?xml version = "1.0" encoding = "utf-8"?>
<!DOCTYPE hibernate-mapping PUBLIC 
"-//Hibernate/Hibernate Mapping DTD//EN"
"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd"> 

<hibernate-mapping>
   <class name = "Employee" table = "EMPLOYEE">
      
      <meta attribute = "class-description">
         This class contains the employee detail. 
      </meta>
      
      <id name = "id" type = "int" column = "id">
         <generator class="native"/>
      </id>
      
      <property name = "firstName" column = "first_name" type = "string"/>
      <property name = "lastName" column = "last_name" type = "string"/>
      <property name = "salary" column = "salary" type = "int"/>
      
   </class>
</hibernate-mapping>

Vous devez enregistrer le document de mappage dans un fichier au format <classname> .hbm.xml. Nous avons enregistré notre document de cartographie dans le fichier Employee.hbm.xml.

Voyons comprendre un petit détail sur les éléments de mappage utilisés dans le fichier de mappage -

  • Le document cartographique est un document XML ayant <hibernate-mapping> comme élément racine, qui contient tous les <class> éléments.

  • le <class>Les éléments sont utilisés pour définir des mappages spécifiques d'une classe Java vers les tables de la base de données. Le nom de la classe Java est spécifié à l'aide duname attribut de l'élément de classe et de la base de données table nom est spécifié à l'aide de l'attribut table.

  • le <meta> element est un élément facultatif et peut être utilisé pour créer la description de classe.

  • le <id>L'élément mappe l'attribut ID unique de la classe à la clé primaire de la table de base de données. lename l'attribut de l'élément id fait référence à la propriété de la classe et le columnL'attribut fait référence à la colonne de la table de base de données. letype L'attribut contient le type de mappage hibernate, ces types de mappage convertiront du type de données Java en type de données SQL.

  • le <generator>L'élément dans l'élément id est utilisé pour générer automatiquement les valeurs de clé primaire. leclass l'attribut de l'élément générateur est défini sur native pour laisser hiberner reprendre soit identity, sequence, ou hilo algorithme pour créer une clé primaire en fonction des capacités de la base de données sous-jacente.

  • le <property>L'élément est utilisé pour mapper une propriété de classe Java à une colonne de la table de base de données. lename l'attribut de l'élément fait référence à la propriété de la classe et le columnL'attribut fait référence à la colonne de la table de base de données. letype L'attribut contient le type de mappage hibernate, ces types de mappage convertiront du type de données Java en type de données SQL.

Il existe d'autres attributs et éléments disponibles, qui seront utilisés dans un document de cartographie et j'essaierais d'en couvrir autant que possible tout en discutant d'autres sujets liés à Hibernate.