Hibernate - Présentation de l'ORM
Qu'est-ce que JDBC?
JDBC signifie Java Database Connectivity. Il fournit un ensemble d'API Java pour accéder aux bases de données relationnelles à partir du programme Java. Ces API Java permettent aux programmes Java d'exécuter des instructions SQL et d'interagir avec n'importe quelle base de données compatible SQL.
JDBC fournit une architecture flexible pour écrire une application indépendante de la base de données qui peut s'exécuter sur différentes plates-formes et interagir avec différents SGBD sans aucune modification.
Avantages et inconvénients de JDBC
Avantages de JDBC | Inconvénients de JDBC |
---|---|
Traitement SQL clair et simple Bonnes performances avec des données volumineuses Très bon pour les petites applications Syntaxe simple si facile à apprendre |
Complexe s'il est utilisé dans de grands projets Grande surcharge de programmation Pas d'encapsulation Difficile à mettre en œuvre le concept MVC La requête est spécifique au SGBD |
Pourquoi Object Relational Mapping (ORM)?
Lorsque nous travaillons avec un système orienté objet, il y a un décalage entre le modèle objet et la base de données relationnelle. Les SGBDR représentent les données dans un format tabulaire tandis que les langages orientés objet, tels que Java ou C #, les représentent sous la forme d'un graphique d'objets interconnectés.
Considérez la classe Java suivante avec les constructeurs appropriés et la fonction publique associée -
public class Employee {
private int id;
private String first_name;
private String last_name;
private int salary;
public Employee() {}
public Employee(String fname, String lname, int salary) {
this.first_name = fname;
this.last_name = lname;
this.salary = salary;
}
public int getId() {
return id;
}
public String getFirstName() {
return first_name;
}
public String getLastName() {
return last_name;
}
public int getSalary() {
return salary;
}
}
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)
);
Premier problème, que se passe-t-il si nous devons modifier le design de notre base de données après avoir développé quelques pages ou notre application? Deuxièmement, le chargement et le stockage d'objets dans une base de données relationnelle nous exposent aux cinq problèmes d'incompatibilité suivants -
N ° Sr. | Non-concordance et description |
---|---|
1 | Granularity Parfois, vous aurez un modèle objet, qui a plus de classes que le nombre de tables correspondantes dans la base de données. |
2 | Inheritance Les SGBDR ne définissent rien de similaire à l'héritage, qui est un paradigme naturel dans les langages de programmation orientés objet. |
3 | Identity Un SGBDR définit exactement une notion de «similitude»: la clé primaire. Java, cependant, définit à la fois l'identité d'objet (a == b) et l'égalité d'objet (a.equals (b)). |
4 | Associations Les langages orientés objet représentent des associations utilisant des références d'objet tandis qu'un SGBDR représente une association en tant que colonne de clé étrangère. |
5 | Navigation Les façons d'accéder aux objets en Java et dans le SGBDR sont fondamentalement différentes. |
le Object-Rexaltation Mapping (ORM) est la solution pour gérer toutes les discordances d'impédance ci-dessus.
Qu'est-ce que l'ORM?
ORM signifie Object-Rexaltation Mapping (ORM) est une technique de programmation permettant de convertir des données entre des bases de données relationnelles et des langages de programmation orientés objet tels que Java, C #, etc.
Un système ORM présente les avantages suivants par rapport au JDBC ordinaire:
N ° Sr. | Avantages |
---|---|
1 | Faisons accès aux objets de code métier plutôt qu'aux tables de base de données. |
2 | Masque les détails des requêtes SQL de la logique OO. |
3 | Basé sur JDBC «sous le capot». |
4 | Pas besoin de s'occuper de l'implémentation de la base de données. |
5 | Entités basées sur des concepts commerciaux plutôt que sur la structure de la base de données. |
6 | Gestion des transactions et génération automatique de clés. |
sept | Développement rapide de l'application. |
Une solution ORM se compose des quatre entités suivantes -
N ° Sr. | Solutions |
---|---|
1 | Une API pour effectuer des opérations CRUD de base sur des objets de classes persistantes. |
2 | Un langage ou une API pour spécifier des requêtes faisant référence à des classes et des propriétés de classes. |
3 | Une fonction configurable pour spécifier les métadonnées de mappage. |
4 | Une technique pour interagir avec des objets transactionnels pour effectuer une vérification incorrecte, une récupération d'association paresseuse et d'autres fonctions d'optimisation. |
Cadres Java ORM
Il existe plusieurs frameworks persistants et options ORM en Java. Un framework persistant est un service ORM qui stocke et récupère des objets dans une base de données relationnelle.
- Beans d'entité Enterprise JavaBeans
- Objets de données Java
- Castor
- TopLink
- Printemps DAO
- Hibernate
- Et beaucoup plus