Hibernate - Requêtes de critères
Hibernate fournit d'autres moyens de manipuler des objets et à son tour les données disponibles dans les tables SGBDR. L'une des méthodes est l'API Criteria, qui vous permet de créer un objet de requête de critères par programme dans lequel vous pouvez appliquer des règles de filtrage et des conditions logiques.
L'Hibernate Session l'interface fournit createCriteria() méthode, qui peut être utilisée pour créer un Criteria objet qui renvoie des instances de la classe de l'objet de persistance lorsque votre application exécute une requête de critères.
Voici l'exemple le plus simple d'une requête de critères est l'un, qui retournera simplement chaque objet correspondant à la classe Employee.
Criteria cr = session.createCriteria(Employee.class);
List results = cr.list();
Restrictions avec critères
Vous pouvez utiliser add() méthode disponible pour Criteriaobjet pour ajouter une restriction à une requête de critères. Voici l'exemple pour ajouter une restriction pour retourner les enregistrements avec le salaire est égal à 2000 -
Criteria cr = session.createCriteria(Employee.class);
cr.add(Restrictions.eq("salary", 2000));
List results = cr.list();
Voici les quelques autres exemples couvrant différents scénarios et peuvent être utilisés selon l'exigence -
Criteria cr = session.createCriteria(Employee.class);
// To get records having salary more than 2000
cr.add(Restrictions.gt("salary", 2000));
// To get records having salary less than 2000
cr.add(Restrictions.lt("salary", 2000));
// To get records having fistName starting with zara
cr.add(Restrictions.like("firstName", "zara%"));
// Case sensitive form of the above restriction.
cr.add(Restrictions.ilike("firstName", "zara%"));
// To get records having salary in between 1000 and 2000
cr.add(Restrictions.between("salary", 1000, 2000));
// To check if the given property is null
cr.add(Restrictions.isNull("salary"));
// To check if the given property is not null
cr.add(Restrictions.isNotNull("salary"));
// To check if the given property is empty
cr.add(Restrictions.isEmpty("salary"));
// To check if the given property is not empty
cr.add(Restrictions.isNotEmpty("salary"));
Vous pouvez créer des conditions AND ou OR à l'aide des restrictions LogicalExpression comme suit -
Criteria cr = session.createCriteria(Employee.class);
Criterion salary = Restrictions.gt("salary", 2000);
Criterion name = Restrictions.ilike("firstNname","zara%");
// To get records matching with OR conditions
LogicalExpression orExp = Restrictions.or(salary, name);
cr.add( orExp );
// To get records matching with AND conditions
LogicalExpression andExp = Restrictions.and(salary, name);
cr.add( andExp );
List results = cr.list();
Bien que toutes les conditions ci-dessus puissent être utilisées directement avec HQL, comme expliqué dans le tutoriel précédent.
Pagination à l'aide de critères
Il existe deux méthodes de l'interface Critères pour la pagination.
N ° Sr. | Méthode et description |
---|---|
1 | public Criteria setFirstResult(int firstResult) Cette méthode prend un entier qui représente la première ligne de votre jeu de résultats, en commençant par la ligne 0. |
2 | public Criteria setMaxResults(int maxResults) Cette méthode indique à Hibernate de récupérer un nombre fixe maxResults d'objets. |
En utilisant les deux méthodes ci-dessus ensemble, nous pouvons construire un composant de pagination dans notre application Web ou Swing. Voici l'exemple que vous pouvez étendre pour récupérer 10 lignes à la fois -
Criteria cr = session.createCriteria(Employee.class);
cr.setFirstResult(1);
cr.setMaxResults(10);
List results = cr.list();
Trier les résultats
L'API Criteria fournit le org.hibernate.criterion.Orderclass pour trier votre jeu de résultats par ordre croissant ou décroissant, en fonction de l'une des propriétés de votre objet. Cet exemple montre comment vous utiliseriez la classe Order pour trier le jeu de résultats -
Criteria cr = session.createCriteria(Employee.class);
// To get records having salary more than 2000
cr.add(Restrictions.gt("salary", 2000));
// To sort records in descening order
cr.addOrder(Order.desc("salary"));
// To sort records in ascending order
cr.addOrder(Order.asc("salary"));
List results = cr.list();
Projections et agrégations
L'API Criteria fournit le org.hibernate.criterion.Projectionsclass, qui peut être utilisée pour obtenir la moyenne, le maximum ou le minimum des valeurs de propriété. La classe Projections est similaire à la classe Restrictions, en ce qu'elle fournit plusieurs méthodes de fabrique statiques pour obtenirProjection instances.
Voici les quelques exemples couvrant différents scénarios et peuvent être utilisés selon les besoins -
Criteria cr = session.createCriteria(Employee.class);
// To get total row count.
cr.setProjection(Projections.rowCount());
// To get average of a property.
cr.setProjection(Projections.avg("salary"));
// To get distinct count of a property.
cr.setProjection(Projections.countDistinct("firstName"));
// To get maximum of a property.
cr.setProjection(Projections.max("salary"));
// To get minimum of a property.
cr.setProjection(Projections.min("salary"));
// To get sum of a property.
cr.setProjection(Projections.sum("salary"));
Exemple de requêtes de critères
Considérez la classe POJO 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;
}
}
Créons la table EMPLOYEE suivante pour stocker les objets Employee -
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)
);
Voici le fichier de mappage.
<?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>
Enfin, nous allons créer notre classe d'application avec la méthode main () pour exécuter l'application où nous allons utiliser Criteria requêtes -
import java.util.List;
import java.util.Date;
import java.util.Iterator;
import org.hibernate.HibernateException;
import org.hibernate.Session;
import org.hibernate.Transaction;
import org.hibernate.SessionFactory;
import org.hibernate.Criteria;
import org.hibernate.criterion.Restrictions;
import org.hibernate.criterion.Projections;
import org.hibernate.cfg.Configuration;
public class ManageEmployee {
private static SessionFactory factory;
public static void main(String[] args) {
try {
factory = new Configuration().configure().buildSessionFactory();
} catch (Throwable ex) {
System.err.println("Failed to create sessionFactory object." + ex);
throw new ExceptionInInitializerError(ex);
}
ManageEmployee ME = new ManageEmployee();
/* Add few employee records in database */
Integer empID1 = ME.addEmployee("Zara", "Ali", 2000);
Integer empID2 = ME.addEmployee("Daisy", "Das", 5000);
Integer empID3 = ME.addEmployee("John", "Paul", 5000);
Integer empID4 = ME.addEmployee("Mohd", "Yasee", 3000);
/* List down all the employees */
ME.listEmployees();
/* Print Total employee's count */
ME.countEmployee();
/* Print Total salary */
ME.totalSalary();
}
/* Method to CREATE an employee in the database */
public Integer addEmployee(String fname, String lname, int salary){
Session session = factory.openSession();
Transaction tx = null;
Integer employeeID = null;
try {
tx = session.beginTransaction();
Employee employee = new Employee(fname, lname, salary);
employeeID = (Integer) session.save(employee);
tx.commit();
} catch (HibernateException e) {
if (tx!=null) tx.rollback();
e.printStackTrace();
} finally {
session.close();
}
return employeeID;
}
/* Method to READ all the employees having salary more than 2000 */
public void listEmployees( ) {
Session session = factory.openSession();
Transaction tx = null;
try {
tx = session.beginTransaction();
Criteria cr = session.createCriteria(Employee.class);
// Add restriction.
cr.add(Restrictions.gt("salary", 2000));
List employees = cr.list();
for (Iterator iterator = employees.iterator(); iterator.hasNext();){
Employee employee = (Employee) iterator.next();
System.out.print("First Name: " + employee.getFirstName());
System.out.print(" Last Name: " + employee.getLastName());
System.out.println(" Salary: " + employee.getSalary());
}
tx.commit();
} catch (HibernateException e) {
if (tx!=null) tx.rollback();
e.printStackTrace();
} finally {
session.close();
}
}
/* Method to print total number of records */
public void countEmployee(){
Session session = factory.openSession();
Transaction tx = null;
try {
tx = session.beginTransaction();
Criteria cr = session.createCriteria(Employee.class);
// To get total row count.
cr.setProjection(Projections.rowCount());
List rowCount = cr.list();
System.out.println("Total Coint: " + rowCount.get(0) );
tx.commit();
} catch (HibernateException e) {
if (tx!=null) tx.rollback();
e.printStackTrace();
} finally {
session.close();
}
}
/* Method to print sum of salaries */
public void totalSalary(){
Session session = factory.openSession();
Transaction tx = null;
try {
tx = session.beginTransaction();
Criteria cr = session.createCriteria(Employee.class);
// To get total salary.
cr.setProjection(Projections.sum("salary"));
List totalSalary = cr.list();
System.out.println("Total Salary: " + totalSalary.get(0) );
tx.commit();
} catch (HibernateException e) {
if (tx!=null) tx.rollback();
e.printStackTrace();
} finally {
session.close();
}
}
}
Compilation et exécution
Voici les étapes pour compiler et exécuter l'application mentionnée ci-dessus. Assurez-vous que vous avez correctement défini PATH et CLASSPATH avant de procéder à la compilation et à l'exécution.
Créez le fichier de configuration hibernate.cfg.xml comme expliqué dans le chapitre de configuration.
Créez le fichier de mappage Employee.hbm.xml comme indiqué ci-dessus.
Créez le fichier source Employee.java comme indiqué ci-dessus et compilez-le.
Créez le fichier source ManageEmployee.java comme indiqué ci-dessus et compilez-le.
Exécutez le binaire ManageEmployee pour exécuter le programme.
Vous obtiendrez le résultat suivant et les enregistrements seraient créés dans la table EMPLOYEE.
$java ManageEmployee
.......VARIOUS LOG MESSAGES WILL DISPLAY HERE........
First Name: Daisy Last Name: Das Salary: 5000
First Name: John Last Name: Paul Salary: 5000
First Name: Mohd Last Name: Yasee Salary: 3000
Total Coint: 4
Total Salary: 15000
Si vous vérifiez votre table EMPLOYEE, elle doit contenir les enregistrements suivants:
mysql> select * from EMPLOYEE;
+----+------------+-----------+--------+
| id | first_name | last_name | salary |
+----+------------+-----------+--------+
| 14 | Zara | Ali | 2000 |
| 15 | Daisy | Das | 5000 |
| 16 | John | Paul | 5000 |
| 17 | Mohd | Yasee | 3000 |
+----+------------+-----------+--------+
4 rows in set (0.00 sec)
mysql>