iBATIS - Guide rapide

iBATIS est un framework de persistance qui automatise le mappage entre les bases de données SQL et les objets en Java, .NET et Ruby on Rails. Les mappages sont découplés de la logique d'application en regroupant les instructions SQL dans des fichiers de configuration XML.

iBATIS est un framework léger et une API de persistance idéale pour les POJO persistants (Plain Old Java Objects).

iBATIS est ce que l'on appelle un mappeur de données et s'occupe de mapper les paramètres et les résultats entre les propriétés de classe et les colonnes de la table de la base de données.

Une différence significative entre iBATIS et d'autres frameworks de persistance tels que Hibernate est qu'iBATIS met l'accent sur l'utilisation de SQL, tandis que d'autres frameworks utilisent généralement un langage de requête personnalisé tel que Hibernate Query Language (HQL) ou Enterprise JavaBeans Query Language (EJB QL).

Philosophies de conception iBATIS

iBATIS est livré avec les philosophies de conception suivantes -

  • Simplicity − iBATIS est largement considéré comme l'un des cadres de persistance les plus simples disponibles aujourd'hui.

  • Fast Development − iBATIS met tout en œuvre pour faciliter le développement ultra-rapide.

  • Portability − iBATIS peut être implémenté pour presque tous les langages ou plates-formes tels que Java, Ruby et C # pour Microsoft .NET.

  • Independent Interfaces − iBATIS fournit des interfaces et des API indépendantes de la base de données qui aident le reste de l'application à rester indépendant de toute ressource liée à la persistance.

  • Open source − iBATIS est un logiciel gratuit et open source.

Avantages d'iBATIS

iBATIS offre les avantages suivants -

  • Supports stored procedures − iBATIS encapsule SQL sous la forme de procédures stockées afin que la logique métier soit maintenue hors de la base de données, et que l'application soit plus facile à déployer et à tester, et plus portable.

  • Supports inline SQL − Aucun précompilateur n'est nécessaire et vous avez un accès complet à toutes les fonctionnalités de SQL.

  • Supports dynamic SQL − iBATIS fournit des fonctionnalités pour créer dynamiquement des requêtes SQL basées sur des paramètres.

  • Supports O/RM − iBATIS prend en charge plusieurs des mêmes fonctionnalités qu'un outil O / RM, telles que le chargement différé, l'extraction de jointures, la mise en cache, la génération de code d'exécution et l'héritage

iBATIS utilise le langage de programmation JAVA tout en développant une application orientée base de données. Avant de continuer, assurez-vous que vous comprenez les bases de la programmation procédurale et orientée objet - structures de contrôle, structures de données et variables, classes, objets, etc.

Pour comprendre JAVA en détail, vous pouvez parcourir notre tutoriel JAVA .

Vous devrez mettre en place un environnement approprié pour iBATIS avant de commencer le travail de développement réel. Ce chapitre explique comment configurer un environnement de travail pour iBATIS.

Installation d'iBATIS

Effectuez les étapes simples suivantes pour installer iBATIS sur votre machine Linux -

  • Téléchargez la dernière version d'iBATIS à partir de Télécharger iBATIS .

  • Décompressez le fichier téléchargé pour extraire le fichier .jar du bundle et conservez-les dans le répertoire lib approprié.

  • Définissez les variables PATH et CLASSPATH sur le ou les fichiers .jar extraits de manière appropriée.

$ unzip ibatis-2.3.4.726.zip inflating: META-INF/MANIFEST.MF creating: doc/ creating: lib/ creating: simple_example/ creating: simple_example/com/ creating: simple_example/com/mydomain/ creating: simple_example/com/mydomain/data/ creating: simple_example/com/mydomain/domain/ creating: src/ inflating: doc/dev-javadoc.zip inflating: doc/user-javadoc.zip inflating: jar-dependencies.txt inflating: lib/ibatis-2.3.4.726.jar inflating: license.txt inflating: notice.txt inflating: release.txt $pwd
/var/home/ibatis
$set PATH=$PATH:/var/home/ibatis/
$set CLASSPATH=$CLASSPATH:/var/home/ibatis\
      /lib/ibatis-2.3.4.726.jar

Configuration de la base de données

Créez une table EMPLOYEE dans n'importe quelle base de données MySQL en utilisant la syntaxe suivante -

mysql> 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)
);

Créer SqlMapConfig.xml

Considérez ce qui suit -

  • Nous allons utiliser JDBC pour accéder à la base de données testdb.

  • Le pilote JDBC pour MySQL est "com.mysql.jdbc.Driver".

  • L'URL de connexion est "jdbc: mysql: // localhost: 3306 / testdb".

  • Nous utiliserions respectivement le nom d'utilisateur et le mot de passe comme "root" et "root".

  • Nos mappages d'instruction SQL pour toutes les opérations seraient décrits dans "Employee.xml".

Sur la base des hypothèses ci-dessus, nous devons créer un fichier de configuration XML avec le nom SqlMapConfig.xmlavec le contenu suivant. C'est là que vous devez fournir toutes les configurations requises pour iBatis -

Il est important que les fichiers SqlMapConfig.xml et Employee.xml soient présents dans le chemin de classe. Pour l'instant, nous garderions le fichier Employee.xml vide et nous en couvririons le contenu dans les chapitres suivants.

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE sqlMapConfig PUBLIC "-//ibatis.apache.org//DTD SQL Map Config 2.0//EN" "http://ibatis.apache.org/dtd/sql-map-config-2.dtd">

<sqlMapConfig>
   <settings useStatementNamespaces="true"/>
	
   <transactionManager type="JDBC">
      <dataSource type="SIMPLE">
		
         <property name="JDBC.Driver" value="com.mysql.jdbc.Driver"/>
         <property name="JDBC.ConnectionURL" value="jdbc:mysql://localhost:3306/testdb"/>
         <property name="JDBC.Username" value="root"/>
         <property name="JDBC.Password" value="root"/>
			
      </dataSource>
   </transactionManager>
	
   <sqlMap resource="Employee.xml"/> 
</sqlMapConfig>

Vous pouvez également définir les propriétés facultatives suivantes à l'aide du fichier SqlMapConfig.xml -

<property name="JDBC.AutoCommit" value="true"/>
<property name="Pool.MaximumActiveConnections" value="10"/>
<property name="Pool.MaximumIdleConnections" value="5"/>
<property name="Pool.MaximumCheckoutTime" value="150000"/> 
<property name="Pool.MaximumTimeToWait" value="500"/> 
<property name="Pool.PingQuery" value="select 1 from Employee"/> 
<property name="Pool.PingEnabled" value="false"/>

Pour effectuer une opération de création, de lecture, de mise à jour et de suppression (CRUD) à l'aide d'iBATIS, vous devez créer une classe POJO (Plain Old Java Objects) correspondant à la table. Cette classe décrit les objets qui «modéliseront» les lignes de la table de base de données.

La classe POJO aurait une implémentation pour toutes les méthodes requises pour effectuer les opérations souhaitées.

Supposons que nous ayons la table EMPLOYEE suivante dans MySQL -

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)
);

Classe POJO des employés

Nous créerions une classe Employee dans le fichier Employee.java comme suit -

public class Employee {
   private int id;
   private String first_name; 
   private String last_name;   
   private int salary;  

   /* Define constructors for the Employee class. */
   public Employee() {}
  
   public Employee(String fname, String lname, int salary) {
      this.first_name = fname;
      this.last_name = lname;
      this.salary = salary;
   }
} /* End of Employee */

Vous pouvez définir des méthodes pour définir des champs individuels dans la table. Le chapitre suivant explique comment obtenir les valeurs de champs individuels.

Fichier Employee.xml

Pour définir l'instruction de mappage SQL en utilisant iBATIS, nous utiliserions la balise <insert> et à l'intérieur de cette définition de balise, nous définirions un "id" qui sera utilisé dans le fichier IbatisInsert.java pour exécuter la requête SQL INSERT sur la base de données.

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE sqlMap PUBLIC "-//ibatis.apache.org//DTD SQL Map 2.0//EN" "http://ibatis.apache.org/dtd/sql-map-2.dtd">

<sqlMap namespace="Employee"> 

   <insert id="insert" parameterClass="Employee">
      insert into EMPLOYEE(first_name, last_name, salary)
      values (#first_name#, #last_name#, #salary#)

      <selectKey resultClass="int" keyProperty="id">
         select last_insert_id() as id
      </selectKey>
   </insert> 

</sqlMap>

Ici parameterClass −peut prendre une valeur sous forme de chaîne, int, flottant, double ou tout objet de classe en fonction des exigences. Dans cet exemple, nous passerions l' objet Employee en tant que paramètre lors de l'appel de la méthode insert de la classe SqlMap.

Si votre table de base de données utilise une colonne IDENTITY, AUTO_INCREMENT ou SERIAL ou si vous avez défini une SEQUENCE / GENERATOR, vous pouvez utiliser l'élément <selectKey> dans une instruction <insert> pour utiliser ou renvoyer cette valeur générée par la base de données.

Fichier IbatisInsert.java

Ce fichier aurait une logique au niveau de l'application pour insérer des enregistrements dans la table Employee -

import com.ibatis.common.resources.Resources;
import com.ibatis.sqlmap.client.SqlMapClient;
import com.ibatis.sqlmap.client.SqlMapClientBuilder;

import java.io.*;
import java.sql.SQLException;
import java.util.*;

public class IbatisInsert{
   public static void main(String[] args)throws IOException,SQLException{
      Reader rd = Resources.getResourceAsReader("SqlMapConfig.xml");
      SqlMapClient smc = SqlMapClientBuilder.buildSqlMapClient(rd);

      /* This would insert one record in Employee table. */
      System.out.println("Going to insert record.....");
      Employee em = new Employee("Zara", "Ali", 5000);

      smc.insert("Employee.insert", em);

      System.out.println("Record Inserted Successfully ");
   }
}

Compilation et exécution

Voici les étapes pour compiler et exécuter le logiciel mentionné 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 Employee.xml comme indiqué ci-dessus.
  • Créez Employee.java comme indiqué ci-dessus et compilez-le.
  • Créez IbatisInsert.java comme indiqué ci-dessus et compilez-le.
  • Exécutez le binaire IbatisInsert pour exécuter le programme.

Vous obtiendrez le résultat suivant et un enregistrement serait créé dans la table EMPLOYEE.

$java IbatisInsert
Going to insert record.....
Record Inserted Successfully

Si vous vérifiez le tableau EMPLOYÉ, il devrait afficher le résultat suivant -

mysql> select * from EMPLOYEE;
+----+------------+-----------+--------+
| id | first_name | last_name | salary |
+----+------------+-----------+--------+
|  1 | Zara       | Ali       |   5000 |
+----+------------+-----------+--------+
1 row in set (0.00 sec)

Nous avons discuté, dans le dernier chapitre, de la façon d'exécuter l'opération CREATE sur une table en utilisant iBATIS. Ce chapitre explique comment lire un tableau à l'aide d'iBATIS.

Nous avons la table EMPLOYEE suivante dans MySQL -

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)
);

Cette table n'a qu'un seul enregistrement comme suit -

mysql> select * from EMPLOYEE;
+----+------------+-----------+--------+
| id | first_name | last_name | salary |
+----+------------+-----------+--------+
|  1 | Zara       | Ali       |   5000 |
+----+------------+-----------+--------+
1 row in set (0.00 sec)

Classe POJO des employés

Pour effectuer une opération de lecture, nous modifierons la classe Employee dans Employee.java comme suit -

public class Employee {
   private int id;
   private String first_name; 
   private String last_name;   
   private int salary;  

   /* Define constructors for the Employee class. */
   public Employee() {}
  
   public Employee(String fname, String lname, int salary) {
      this.first_name = fname;
      this.last_name = lname;
      this.salary = salary;
   }

   /* Here are the method definitions */
   public int getId() {
      return id;
   }
	
   public String getFirstName() {
      return first_name;
   }
	
   public String getLastName() {
      return last_name;
   }
	
   public int getSalary() {
      return salary;
   }
	
} /* End of Employee */

Fichier Employee.xml

Pour définir l'instruction de mappage SQL en utilisant iBATIS, nous ajouterions la balise <select> dans le fichier Employee.xml et à l'intérieur de cette définition de balise, nous définirions un «id» qui sera utilisé dans le fichier IbatisRead.java pour exécuter la requête SQL SELECT sur la base de données.

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE sqlMap PUBLIC "-//ibatis.apache.org//DTD SQL Map 2.0//EN" "http://ibatis.apache.org/dtd/sql-map-2.dtd">

<sqlMap namespace="Employee">

   <insert id="insert" parameterClass="Employee">
      INSERT INTO EMPLOYEE(first_name, last_name, salary)
      values (#first_name#, #last_name#, #salary#)

      <selectKey resultClass="int" keyProperty="id">
         select last_insert_id() as id
      </selectKey>
   </insert>
	
   <select id="getAll" resultClass="Employee">
      SELECT * FROM EMPLOYEE
   </select>
	
</sqlMap>

Ici, nous n'avons pas utilisé la clause WHERE avec l'instruction SQL SELECT. Nous montrerons, dans le chapitre suivant, comment vous pouvez utiliser la clause WHERE avec l'instruction SELECT et comment vous pouvez passer des valeurs à cette clause WHERE.

Fichier IbatisRead.java

Ce fichier a une logique au niveau de l'application pour lire les enregistrements de la table Employee -

import com.ibatis.common.resources.Resources;
import com.ibatis.sqlmap.client.SqlMapClient;
import com.ibatis.sqlmap.client.SqlMapClientBuilder;

import java.io.*;
import java.sql.SQLException;
import java.util.*;

public class IbatisRead{
   public static void main(String[] args)throws IOException,SQLException{
      Reader rd = Resources.getResourceAsReader("SqlMapConfig.xml");
      SqlMapClient smc = SqlMapClientBuilder.buildSqlMapClient(rd);

      /* This would read all records from the Employee table. */
      System.out.println("Going to read records.....");
      List <Employee> ems = (List<Employee>)
         smc.queryForList("Employee.getAll", null);
      Employee em = null;
		
      for (Employee e : ems) {
         System.out.print("  " + e.getId());
         System.out.print("  " + e.getFirstName());
         System.out.print("  " + e.getLastName());
         System.out.print("  " + e.getSalary());
         em = e; 
         System.out.println("");
      }    
		
      System.out.println("Records Read Successfully ");
   }
}

Compilation et exécution

Voici les étapes pour compiler et exécuter le logiciel mentionné 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 Employee.xml comme indiqué ci-dessus.
  • Créez Employee.java comme indiqué ci-dessus et compilez-le.
  • Créez IbatisRead.java comme indiqué ci-dessus et compilez-le.
  • Exécutez le binaire IbatisRead pour exécuter le programme.

Vous obtiendrez le résultat suivant et un enregistrement serait lu à partir de la table EMPLOYEE comme suit -

Going to read records.....
   1  Zara  Ali  5000
Record Reads Successfully

Nous avons discuté, dans le dernier chapitre, de la manière d'effectuer une opération de lecture sur une table à l'aide d'iBATIS. Ce chapitre explique comment mettre à jour les enregistrements dans une table à l'aide d'iBATIS.

Nous avons la table EMPLOYEE suivante dans MySQL -

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)
);

Cette table n'a qu'un seul enregistrement comme suit -

mysql> select * from EMPLOYEE;
+----+------------+-----------+--------+
| id | first_name | last_name | salary |
+----+------------+-----------+--------+
|  1 | Zara       | Ali       |   5000 |
+----+------------+-----------+--------+
1 row in set (0.00 sec)

Classe POJO des employés

Pour effectuer l'opération udpate, vous devez modifier le fichier Employee.java comme suit -

public class Employee {
   private int id;
   private String first_name; 
   private String last_name;   
   private int salary;  

   /* Define constructors for the Employee class. */
   public Employee() {}
  
   public Employee(String fname, String lname, int salary) {
      this.first_name = fname;
      this.last_name = lname;
      this.salary = salary;
   }

   /* Here are the required method definitions */
   public int getId() {
      return id;
   }
	
   public void setId(int id) {
      this.id = id;
   }
	
   public String getFirstName() {
      return first_name;
   }
	
   public void setFirstName(String fname) {
      this.first_name = fname;
   }
	
   public String getLastName() {
      return last_name;
   }
   public void setlastName(String lname) {
      this.last_name = lname;
   }
	
   public int getSalary() {
      return salary;
   }
	
   public void setSalary(int salary) {
      this.salary = salary;
   }

} /* End of Employee */

Fichier Employee.xml

Pour définir l'instruction de mappage SQL en utilisant iBATIS, nous ajouterions la balise <update> dans Employee.xml et à l'intérieur de cette définition de balise, nous définirions un «id» qui sera utilisé dans le fichier IbatisUpdate.java pour exécuter la requête SQL UPDATE sur la base de données.

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE sqlMap PUBLIC "-//ibatis.apache.org//DTD SQL Map 2.0//EN" "http://ibatis.apache.org/dtd/sql-map-2.dtd">

<sqlMap namespace="Employee">

   <insert id="insert" parameterClass="Employee">
      INSERT INTO EMPLOYEE(first_name, last_name, salary)
      values (#first_name#, #last_name#, #salary#)

      <selectKey resultClass="int" keyProperty="id">
         select last_insert_id() as id
      </selectKey>
   </insert>

   <select id="getAll" resultClass="Employee">
      SELECT * FROM EMPLOYEE
   </select>

   <update id="update" parameterClass="Employee">
      UPDATE EMPLOYEE
      SET    first_name = #first_name#
      WHERE  id = #id#
   </update>
	
</sqlMap>

Fichier IbatisUpdate.java

Ce fichier a une logique de niveau application pour mettre à jour les enregistrements dans la table Employé -

import com.ibatis.common.resources.Resources;
import com.ibatis.sqlmap.client.SqlMapClient;
import com.ibatis.sqlmap.client.SqlMapClientBuilder;

import java.io.*;
import java.sql.SQLException;
import java.util.*;

public class IbatisUpdate{
   public static void main(String[] args)
   throws IOException,SQLException{
      Reader rd = Resources.getResourceAsReader("SqlMapConfig.xml");
      SqlMapClient smc = SqlMapClientBuilder.buildSqlMapClient(rd);

      /* This would update one record in Employee table. */
      System.out.println("Going to update record.....");
      Employee rec = new Employee();
      rec.setId(1);
      rec.setFirstName( "Roma");
      smc.update("Employee.update", rec );
      System.out.println("Record updated Successfully ");

      System.out.println("Going to read records.....");
      List <Employee> ems = (List<Employee>)
         smc.queryForList("Employee.getAll", null);
      Employee em = null;
		
      for (Employee e : ems) {
         System.out.print("  " + e.getId());
         System.out.print("  " + e.getFirstName());
         System.out.print("  " + e.getLastName());
         System.out.print("  " + e.getSalary());
         em = e; 
         System.out.println("");
      }    

      System.out.println("Records Read Successfully ");
   }
}

Compilation et exécution

Voici les étapes pour compiler et exécuter le logiciel mentionné 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 Employee.xml comme indiqué ci-dessus.
  • Créez Employee.java comme indiqué ci-dessus et compilez-le.
  • Créez IbatisUpdate.java comme indiqué ci-dessus et compilez-le.
  • Exécutez le binaire IbatisUpdate pour exécuter le programme.

Vous obtiendrez le résultat suivant, et un enregistrement serait mis à jour dans la table EMPLOYEE et plus tard, le même enregistrement serait lu à partir de la table EMPLOYEE.

Going to update record.....
Record updated Successfully
Going to read records.....
   1  Roma  Ali  5000
Records Read Successfully

Ce chapitre décrit comment supprimer des enregistrements d'une table à l'aide d'iBATIS.

Nous avons la table EMPLOYEE suivante dans MySQL -

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)
);

Supposons que cette table comporte deux enregistrements comme suit -

mysql> select * from EMPLOYEE;
+----+------------+-----------+--------+
| id | first_name | last_name | salary |
+----+------------+-----------+--------+
|  1 | Zara       | Ali       |   5000 |
|  2 | Roma       | Ali       |   3000 |
+----+------------+-----------+--------+
2 row in set (0.00 sec)

Classe POJO des employés

Pour effectuer l'opération de suppression, vous n'avez pas besoin de modifier le fichier Employee.java. Gardons-le tel qu'il était dans le dernier chapitre.

public class Employee {
   private int id;
   private String first_name; 
   private String last_name;   
   private int salary;  

   /* Define constructors for the Employee class. */
   public Employee() {}
  
   public Employee(String fname, String lname, int salary) {
      this.first_name = fname;
      this.last_name = lname;
      this.salary = salary;
   }

   /* Here are the required method definitions */
   public int getId() {
      return id;
   }
	
   public void setId(int id) {
      this.id = id;
   }
	
   public String getFirstName() {
      return first_name;
   }
	
   public void setFirstName(String fname) {
      this.first_name = fname;
   }
	
   public String getLastName() {
      return last_name;
   }
	
   public void setlastName(String lname) {
      this.last_name = lname;
   }
	
   public int getSalary() {
      return salary;
   }
	
   public void setSalary(int salary) {
      this.salary = salary;
   }

} /* End of Employee */

Fichier Employee.xml

Pour définir l'instruction de mappage SQL en utilisant iBATIS, nous ajouterions la balise <delete> dans Employee.xml et à l'intérieur de cette définition de balise, nous définirions un «id» qui sera utilisé dans le fichier IbatisDelete.java pour exécuter la requête SQL DELETE sur la base de données.

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE sqlMap PUBLIC "-//ibatis.apache.org//DTD SQL Map 2.0//EN" "http://ibatis.apache.org/dtd/sql-map-2.dtd">

<sqlMap namespace="Employee">

   <insert id="insert" parameterClass="Employee">
      INSERT INTO EMPLOYEE(first_name, last_name, salary)
      values (#first_name#, #last_name#, #salary#)

      <selectKey resultClass="int" keyProperty="id">
         select last_insert_id() as id
      </selectKey>
   </insert>

   <select id="getAll" resultClass="Employee">
      SELECT * FROM EMPLOYEE
   </select>

   <update id="update" parameterClass="Employee">
      UPDATE EMPLOYEE
      SET    first_name = #first_name#
      WHERE  id = #id#
   </update>

   <delete id="delete" parameterClass="int">
      DELETE FROM EMPLOYEE
      WHERE  id = #id#
   </delete>

</sqlMap>

Fichier IbatisDelete.java

Ce fichier a une logique au niveau de l'application pour supprimer des enregistrements de la table Employé -

import com.ibatis.common.resources.Resources;
import com.ibatis.sqlmap.client.SqlMapClient;
import com.ibatis.sqlmap.client.SqlMapClientBuilder;

import java.io.*;
import java.sql.SQLException;
import java.util.*;

public class IbatisDelete{
   public static void main(String[] args)
   throws IOException,SQLException{
      Reader rd = Resources.getResourceAsReader("SqlMapConfig.xml");
      SqlMapClient smc = SqlMapClientBuilder.buildSqlMapClient(rd);

      /* This would delete one record in Employee table. */
      System.out.println("Going to delete record.....");
      int id = 1;

      smc.delete("Employee.delete", id );
      System.out.println("Record deleted Successfully ");

      System.out.println("Going to read records.....");
      List <Employee> ems = (List<Employee>)
         smc.queryForList("Employee.getAll", null);
      Employee em = null;
		
      for (Employee e : ems) {
         System.out.print("  " + e.getId());
         System.out.print("  " + e.getFirstName());
         System.out.print("  " + e.getLastName());
         System.out.print("  " + e.getSalary());
         em = e; 
         System.out.println("");
      }    

      System.out.println("Records Read Successfully ");
   }
}

Compilation et exécution

Voici les étapes pour compiler et exécuter le logiciel mentionné 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 Employee.xml comme indiqué ci-dessus.
  • Créez Employee.java comme indiqué ci-dessus et compilez-le.
  • Créez IbatisDelete.java comme indiqué ci-dessus et compilez-le.
  • Exécutez le binaire IbatisDelete pour exécuter le programme.

Vous obtiendrez le résultat suivant, et un enregistrement avec ID = 1 serait supprimé de la table EMPLOYEE et le reste des enregistrements serait lu.

Going to delete record.....
Record deleted Successfully
Going to read records.....
   2  Roma  Ali  3000
Records Read Successfully

L'élément resultMap est l'élément le plus important et le plus puissant d'iBATIS. Vous pouvez réduire jusqu'à 90% le codage JDBC en utilisant iBATIS ResultMap et dans certains cas, cela vous permet de faire des choses que JDBC ne prend même pas en charge.

La conception de ResultMaps est telle que les instructions simples ne nécessitent pas du tout de mappages de résultats explicites, et les instructions plus complexes ne nécessitent pas plus que ce qui est absolument nécessaire pour décrire les relations.

Ce chapitre n'est qu'une simple introduction à iBATIS ResultMaps.

Nous avons la table EMPLOYEE suivante dans MySQL -

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)
);

Cette table a deux enregistrements comme suit -

mysql> select * from EMPLOYEE;
+----+------------+-----------+--------+
| id | first_name | last_name | salary |
+----+------------+-----------+--------+
|  1 | Zara       | Ali       |   5000 |
|  2 | Roma       | Ali       |   3000 |
+----+------------+-----------+--------+
2 row in set (0.00 sec)

Classe POJO des employés

Pour utiliser iBATIS ResultMap, vous n'avez pas besoin de modifier le fichier Employee.java. Gardons-le tel qu'il était dans le dernier chapitre.

public class Employee {
   private int id;
   private String first_name; 
   private String last_name;   
   private int salary;  

   /* Define constructors for the Employee class. */
   public Employee() {}
  
   public Employee(String fname, String lname, int salary) {
      this.first_name = fname;
      this.last_name = lname;
      this.salary = salary;
   }

   /* Here are the required method definitions */
   public int getId() {
      return id;
   }
	
   public void setId(int id) {
      this.id = id;
   }
	
   public String getFirstName() {
      return first_name;
   }
	
   public void setFirstName(String fname) {
      this.first_name = fname;
   }
	
   public String getLastName() {
      return last_name;
   }
	
   public void setlastName(String lname) {
      this.last_name = lname;
   }
	
   public int getSalary() {
      return salary;
   }
	
   public void setSalary(int salary) {
      this.salary = salary;
   }

} /* End of Employee */

Fichier Employee.xml

Ici, nous modifierions Employee.xml pour introduire la balise <resultMap> </resultMap>. Cette balise aurait un identifiant qui est requis pour exécuter ce resultMap dans l'attribut resultMap de notre balise <select>.

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE sqlMap PUBLIC "-//ibatis.apache.org//DTD SQL Map 2.0//EN" "http://ibatis.apache.org/dtd/sql-map-2.dtd">

<sqlMap namespace="Employee">

   <!-- Perform Insert Operation -->
	
   <insert id="insert" parameterClass="Employee">
      INSERT INTO EMPLOYEE(first_name, last_name, salary)
      values (#first_name#, #last_name#, #salary#)

      <selectKey resultClass="int" keyProperty="id">
         select last_insert_id() as id
      </selectKey>
   </insert>

   <!-- Perform Read Operation -->
   <select id="getAll" resultClass="Employee">
      SELECT * FROM EMPLOYEE
   </select>

   <!-- Perform Update Operation -->
   <update id="update" parameterClass="Employee">
      UPDATE EMPLOYEE
      SET    first_name = #first_name#
      WHERE  id = #id#
    </update>

   <!-- Perform Delete Operation -->
   <delete id="delete" parameterClass="int">
      DELETE FROM EMPLOYEE
      WHERE  id = #id#
   </delete>

   <!-- Using ResultMap -->
   <resultMap id="result" class="Employee">
      <result property="id" column="id"/>
      <result property="first_name" column="first_name"/>
      <result property="last_name" column="last_name"/>
      <result property="salary" column="salary"/>
   </resultMap> 
	
   <select id="useResultMap" resultMap="result">
      SELECT * FROM EMPLOYEE
      WHERE id=#id#
   </select>

</sqlMap>

Fichier IbatisResultMap.java

Ce fichier a une logique au niveau de l'application pour lire les enregistrements de la table Employee à l'aide de ResultMap -

import com.ibatis.common.resources.Resources;
import com.ibatis.sqlmap.client.SqlMapClient;
import com.ibatis.sqlmap.client.SqlMapClientBuilder;

import java.io.*;
import java.sql.SQLException;
import java.util.*;

public class IbatisResultMap{
   public static void main(String[] args)
   throws IOException,SQLException{
      Reader rd = Resources.getResourceAsReader("SqlMapConfig.xml");
      SqlMapClient smc = SqlMapClientBuilder.buildSqlMapClient(rd);

      int id = 1;
      System.out.println("Going to read record.....");
      Employee e = (Employee)smc.queryForObject ("Employee.useResultMap", id);

      System.out.println("ID:  " + e.getId());
      System.out.println("First Name:  " + e.getFirstName());
      System.out.println("Last Name:  " + e.getLastName());
      System.out.println("Salary:  " + e.getSalary());
      System.out.println("Record read Successfully ");
   }
}

Compilation et exécution

Voici les étapes pour compiler et exécuter le logiciel mentionné 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 Employee.xml comme indiqué ci-dessus.
  • Créez Employee.java comme indiqué ci-dessus et compilez-le.
  • Créez IbatisResultMap.java comme indiqué ci-dessus et compilez-le.
  • Exécutez le binaire IbatisResultMap pour exécuter le programme.

Vous obtiendrez le résultat suivant qui est une opération de lecture sur la table EMPLOYEE.

Going to read record.....
ID:  1
First Name:  Zara
Last Name:  Ali
Salary:  5000
Record read Successfully

Vous pouvez appeler une procédure stockée à l'aide de la configuration iBATIS. Tout d'abord, voyons comment créer une procédure stockée dans MySQL.

Nous avons la table EMPLOYEE suivante dans MySQL -

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)
);

Créons la procédure stockée suivante dans la base de données MySQL -

DELIMITER $$

   DROP PROCEDURE IF EXISTS `testdb`.`getEmp` $$ CREATE PROCEDURE `testdb`.`getEmp` (IN empid INT) BEGIN SELECT * FROM EMPLOYEE WHERE ID = empid; END $$

DELIMITER;

Considérons que la table EMPLOYEE a deux enregistrements comme suit -

mysql> select * from EMPLOYEE;
+----+------------+-----------+--------+
| id | first_name | last_name | salary |
+----+------------+-----------+--------+
|  1 | Zara       | Ali       |   5000 |
|  2 | Roma       | Ali       |   3000 |
+----+------------+-----------+--------+
2 row in set (0.00 sec)

Classe POJO des employés

Pour utiliser la procédure stockée, vous n'avez pas besoin de modifier le fichier Employee.java. Gardons-le tel qu'il était dans le dernier chapitre.

public class Employee {
   private int id;
   private String first_name; 
   private String last_name;   
   private int salary;  

   /* Define constructors for the Employee class. */
   public Employee() {}
  
   public Employee(String fname, String lname, int salary) {
      this.first_name = fname;
      this.last_name = lname;
      this.salary = salary;
   }

   /* Here are the required method definitions */
   public int getId() {
      return id;
   }
	
   public void setId(int id) {
      this.id = id;
   }
	
   public String getFirstName() {
      return first_name;
   }
	
   public void setFirstName(String fname) {
      this.first_name = fname;
   }
	
   public String getLastName() {
      return last_name;
   }
	
   public void setlastName(String lname) {
      this.last_name = lname;
   }
	
   public int getSalary() {
      return salary;
   }
	
   public void setSalary(int salary) {
      this.salary = salary;
   }

} /* End of Employee */

Fichier Employee.xml

Ici, nous modifierions Employee.xml pour introduire les balises <procedure> </procedure> et <parameterMap> </parameterMap>. Ici, la balise <procedure> </procedure> aurait un identifiant que nous utiliserions dans notre application pour appeler la procédure stockée.

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE sqlMap PUBLIC "-//ibatis.apache.org//DTD SQL Map 2.0//EN" "http://ibatis.apache.org/dtd/sql-map-2.dtd">

<sqlMap namespace="Employee">

   <!-- Perform Insert Operation -->
   <insert id="insert" parameterClass="Employee">
      INSERT INTO EMPLOYEE(first_name, last_name, salary)
      values (#first_name#, #last_name#, #salary#)

      <selectKey resultClass="int" keyProperty="id">
         select last_insert_id() as id
      </selectKey>
   </insert>

   <!-- Perform Read Operation -->
   <select id="getAll" resultClass="Employee">
      SELECT * FROM EMPLOYEE
   </select>

   <!-- Perform Update Operation -->
   <update id="update" parameterClass="Employee">
      UPDATE EMPLOYEE
      SET    first_name = #first_name#
      WHERE  id = #id#
   </update>

   <!-- Perform Delete Operation -->
   <delete id="delete" parameterClass="int">
      DELETE FROM EMPLOYEE
      WHERE  id = #id#
   </delete>

   <!-- To call stored procedure. -->
   <procedure id="getEmpInfo" resultClass="Employee" parameterMap="getEmpInfoCall">
      { call getEmp( #acctID# ) } 
   </procedure>
	
   <parameterMap id="getEmpInfoCall" class="map">
      <parameter property="acctID" jdbcType="INT" javaType="java.lang.Integer" mode="IN"/>
   </parameterMap>

</sqlMap>

Fichier IbatisSP.java

Ce fichier a une logique au niveau de l'application pour lire les noms des employés de la table Employee à l'aide de ResultMap -

import com.ibatis.common.resources.Resources;
import com.ibatis.sqlmap.client.SqlMapClient;
import com.ibatis.sqlmap.client.SqlMapClientBuilder;

import java.io.*;
import java.sql.SQLException;
import java.util.*;

public class IbatisSP{
   public static void main(String[] args)
   throws IOException,SQLException{
      Reader rd = Resources.getResourceAsReader("SqlMapConfig.xml");
      SqlMapClient smc = SqlMapClientBuilder.buildSqlMapClient(rd);

      int id = 1;
      System.out.println("Going to read employee name.....");
      Employee e = (Employee) smc.queryForObject ("Employee.getEmpInfo", id);

      System.out.println("First Name:  " + e.getFirstName());
      System.out.println("Record name Successfully ");
   }
}

Compilation et exécution

Voici les étapes pour compiler et exécuter le logiciel mentionné 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 Employee.xml comme indiqué ci-dessus.
  • Créez Employee.java comme indiqué ci-dessus et compilez-le.
  • Créez IbatisSP.java comme indiqué ci-dessus et compilez-le.
  • Exécutez le binaire IbatisSP pour exécuter le programme.

Vous obtiendrez le résultat suivant:

Going to read employee name.....
First Name:  Zara
Record name Successfully

Dynamic SQL est une fonctionnalité très puissante d'iBATIS. Parfois, vous devez modifier le critère de la clause WHERE en fonction de l'état de votre objet paramètre. Dans de telles situations, iBATIS fournit un ensemble de balises SQL dynamiques qui peuvent être utilisées dans des instructions mappées pour améliorer la réutilisabilité et la flexibilité du SQL.

Toute la logique est placée dans un fichier .XML en utilisant des balises supplémentaires. Voici un exemple où l'instruction SELECT fonctionnerait de deux manières -

Si vous transmettez un identifiant, il renverra tous les enregistrements correspondant à cet identifiant.

Sinon, il renverrait tous les enregistrements où l'ID d'employé est défini sur NULL.

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE sqlMap PUBLIC "-//ibatis.apache.org//DTD SQL Map 2.0//EN" "http://ibatis.apache.org/dtd/sql-map-2.dtd">

<sqlMap namespace="Employee">

   <select id="findByID" resultClass="Employee">
      SELECT * FROM EMPLOYEE
		
      <dynamic prepend="WHERE ">
         <isNull property="id">
            id IS NULL
         </isNull>
			
         <isNotNull property="id">
            id = #id#
         </isNotNull>
      </dynamic>
		
   </select>
</sqlMap>

Vous pouvez vérifier une condition à l'aide de la balise <isNotEmpty> comme suit. Ici, une condition ne serait ajoutée que lorsqu'une propriété passée n'est pas vide.

..................
<select id="findByID" resultClass="Employee">
   SELECT * FROM EMPLOYEE
	
   <dynamic prepend="WHERE ">
      <isNotEmpty property="id">
         id = #id#
      </isNotEmpty>
   </dynamic>
	
</select>
..................

Si vous voulez une requête où nous pouvons sélectionner un identifiant et / ou le prénom d'un employé, votre instruction SELECT serait la suivante -

..................
<select id="findByID" resultClass="Employee">
   SELECT * FROM EMPLOYEE
	
   <dynamic prepend="WHERE ">
      <isNotEmpty prepend="AND" property="id">
         id = #id#
      </isNotEmpty>
		
      <isNotEmpty prepend="OR" property="first_name">
         first_name = #first_name#
      </isNotEmpty>
   </dynamic>
</select>
..................

Exemple de SQL dynamique

L'exemple suivant montre comment vous pouvez écrire une instruction SELECT avec SQL dynamique. Considérez, nous avons la table EMPLOYEE suivante dans MySQL -

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)
);

Supposons que cette table n'a qu'un seul enregistrement comme suit -

mysql> select * from EMPLOYEE;
+----+------------+-----------+--------+
| id | first_name | last_name | salary |
+----+------------+-----------+--------+
|  1 | Zara       | Ali       |   5000 |
+----+------------+-----------+--------+
1 row in set (0.00 sec)

Classe POJO des employés

Pour effectuer l'opération de lecture, ayons une classe Employee dans Employee.java comme suit -

public class Employee {
   private int id;
   private String first_name; 
   private String last_name;   
   private int salary;  

   /* Define constructors for the Employee class. */
   public Employee() {}
  
   public Employee(String fname, String lname, int salary) {
      this.first_name = fname;
      this.last_name = lname;
      this.salary = salary;
   }

   /* Here are the method definitions */
   public int getId() {
      return id;
   }
	
   public String getFirstName() {
      return first_name;
   }
	
   public String getLastName() {
      return last_name;
   }
	
   public int getSalary() {
      return salary;
   }
	
} /* End of Employee */

Fichier Employee.xml

Pour définir l'instruction de mappage SQL à l'aide d'iBATIS, nous ajouterions la balise <select> modifiée suivante dans Employee.xml et à l'intérieur de cette définition de balise, nous définirions un «id» qui sera utilisé dans IbatisReadDy.java pour exécuter la requête Dynamic SQL SELECT sur base de données.

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE sqlMap PUBLIC "-//ibatis.apache.org//DTD SQL Map 2.0//EN" "http://ibatis.apache.org/dtd/sql-map-2.dtd">

<sqlMap namespace="Employee">
   <select id="findByID" resultClass="Employee">
      SELECT * FROM EMPLOYEE
	
      <dynamic prepend="WHERE ">
         <isNotNull property="id">
            id = #id#
         </isNotNull>
      </dynamic>
		
   </select>
</sqlMap>

L'instruction SELECT ci-dessus fonctionnerait de deux manières -

  • Si vous transmettez un ID, il renvoie les enregistrements correspondant à cet ID. Sinon, il renvoie tous les enregistrements.

Fichier IbatisReadDy.java

Ce fichier a une logique au niveau de l'application pour lire les enregistrements conditionnels de la table Employee -

import com.ibatis.common.resources.Resources;
import com.ibatis.sqlmap.client.SqlMapClient;
import com.ibatis.sqlmap.client.SqlMapClientBuilder;

import java.io.*;
import java.sql.SQLException;
import java.util.*;

public class IbatisReadDy{
   public static void main(String[] args)
   throws IOException,SQLException{
      Reader rd=Resources.getResourceAsReader("SqlMapConfig.xml");
      SqlMapClient smc=SqlMapClientBuilder.buildSqlMapClient(rd);

      /* This would read all records from the Employee table.*/
      System.out.println("Going to read records.....");
      Employee rec = new Employee();
      rec.setId(1);

      List <Employee> ems = (List<Employee>)  
         smc.queryForList("Employee.findByID", rec);
      Employee em = null;
		
      for (Employee e : ems) {
         System.out.print("  " + e.getId());
         System.out.print("  " + e.getFirstName());
         System.out.print("  " + e.getLastName());
         System.out.print("  " + e.getSalary());
         em = e; 
         System.out.println("");
      }    
      System.out.println("Records Read Successfully ");
   }
}

Compilation et exécution

Voici les étapes pour compiler et exécuter le logiciel mentionné 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 Employee.xml comme indiqué ci-dessus.
  • Créez Employee.java comme indiqué ci-dessus et compilez-le.
  • Créez IbatisReadDy.java comme indiqué ci-dessus et compilez-le.
  • Exécutez le binaire IbatisReadDy pour exécuter le programme.

Vous obtiendrez le résultat suivant et un enregistrement serait lu à partir de la table EMPLOYEE.

Going to read records.....
   1  Zara  Ali  5000
Record Reads Successfully

Essayez l'exemple ci-dessus en passant nullcomme smc.queryForList ("Employee.findByID", null) .

Expressions iBATIS OGNL

iBATIS fournit de puissantes expressions basées sur OGNL pour éliminer la plupart des autres éléments.

  • if Déclaration
  • choisir, quand, sinon Déclaration
  • où Déclaration
  • Déclaration foreach

La déclaration if

La chose la plus courante à faire en SQL dynamique est d'inclure conditionnellement une partie d'une clause where. Par exemple -

<select id="findActiveBlogWithTitleLike" parameterType="Blog" resultType="Blog">
   SELECT * FROM BLOG
   WHERE state = 'ACTIVE.
	
   <if test="title != null">
      AND title like #{title}
   </if>
	
</select>

Cette instruction fournit un type de fonctionnalité de recherche de texte facultatif. Si vous ne transmettez aucun titre, tous les blogs actifs sont renvoyés. Mais si vous passez un titre, il cherchera un titre avec lelike état.

Vous pouvez inclure plusieurs if conditions comme suit -

<select id="findActiveBlogWithTitleLike" parameterType="Blog" resultType="Blog">
   SELECT * FROM BLOG
   WHERE state = 'ACTIVE.
	
   <if test="title != null">
      AND title like #{title}
   </if>
	
   <if test="author != null">
      AND author like #{author}
   </if>
	
</select>

Les déclarations de choix, de quand et autrement

iBATIS propose un chooseélément similaire à l'instruction switch de Java. Cela permet de ne choisir qu'un seul cas parmi de nombreuses options.

L'exemple suivant rechercherait uniquement par titre si un est fourni, puis uniquement par auteur si un est fourni. Si ni l'un ni l'autre n'est fourni, il ne renvoie que les blogs en vedette -

<select id="findActiveBlogWithTitleLike" parameterType="Blog" resultType="Blog">
   SELECT * FROM BLOG
   WHERE state = 'ACTIVE.
	
   <choose>
      <when test="title != null">
         AND title like #{title}
      </when>
		
      <when test="author != null and author.name != null">
         AND author like #{author}
      </when>
		
      <otherwise>
         AND featured = 1
      </otherwise>
   </choose>
	
</select>

La déclaration where

Jetez un œil à nos exemples précédents pour voir ce qui se passe si aucune des conditions n'est remplie. Vous vous retrouveriez avec un SQL qui ressemble à ceci -

SELECT * FROM BLOG
WHERE

Cela échouerait, mais iBATIS a une solution simple avec un simple changement, tout fonctionne bien -

<select id="findActiveBlogLike" parameterType="Blog" resultType="Blog">
   SELECT * FROM BLOG
	
   <where>
      <if test="state != null">
         state = #{state}
      </if>
		
      <if test="title != null">
         AND title like #{title}
      </if>
		
      <if test="author != null>
         AND author like #{author}
      </if>
   </where>
	
</select>

le whereelement insère un WHERE uniquement lorsque les balises contenant renvoient un contenu. De plus, si ce contenu commence par AND ou OR, il sait le supprimer.

La déclaration foreach

L'élément foreach vous permet de spécifier une collection et de déclarer des variables d'élément et d'index qui peuvent être utilisées dans le corps de l'élément.

Il vous permet également de spécifier des chaînes d'ouverture et de fermeture et d'ajouter un séparateur à placer entre les itérations. Vous pouvez construire unIN condition comme suit -

<select id="selectPostIn" resultType="domain.blog.Post">
   SELECT *
   FROM POST P
   WHERE ID in
	
   <foreach item="item" index="index" collection="list"
      open="(" separator="," close=")">
      #{item}
   </foreach>
	
</select>

Il est facile de déboguer votre programme tout en travaillant avec iBATIS. iBATIS a un support de journalisation intégré et il fonctionne avec les bibliothèques de journalisation suivantes et les recherche dans cet ordre.

  • Journalisation de Jakarta Commons (JCL).
  • Log4J
  • Journalisation JDK

Vous pouvez utiliser l'une des bibliothèques énumérées ci-dessus avec iBATIS.

Débogage avec Log4J

En supposant que vous utilisiez Log4J pour la journalisation. Avant de continuer, vous devez vérifier les points suivants -

  • Le fichier JAR Log4J (log4j- {version} .jar) doit se trouver dans le CLASSPATH.
  • Vous avez log4j.properties disponible dans CLASSPATH.

Voici le fichier log4j.properties. Notez que certaines lignes sont commentées. Vous pouvez les décommenter si vous avez besoin d'informations de débogage supplémentaires.

# Global logging configuration
log4j.rootLogger = ERROR, stdout

log4j.logger.com.ibatis = DEBUG

# shows SQL of prepared statements
#log4j.logger.java.sql.Connection = DEBUG

# shows parameters inserted into prepared statements
#log4j.logger.java.sql.PreparedStatement = DEBUG

# shows query results
#log4j.logger.java.sql.ResultSet = DEBUG

#log4j.logger.java.sql.Statement = DEBUG

# Console output
log4j.appender.stdout = org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout = org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern = %5p [%t] − %m%n

Vous pouvez trouver la documentation complète de Log4J sur le site Apaches - Documentation Log4J .

Exemple de débogage iBATIS

La classe Java suivante est un exemple très simple qui initialise puis utilise la bibliothèque de journalisation Log4J pour les applications Java. Nous utiliserions le fichier de propriétés mentionné ci-dessus qui se trouve dans CLASSPATH.

import org.apache.log4j.Logger;

import com.ibatis.common.resources.Resources;
import com.ibatis.sqlmap.client.SqlMapClient;
import com.ibatis.sqlmap.client.SqlMapClientBuilder;

import java.io.*;
import java.sql.SQLException;
import java.util.*;

public class IbatisUpdate{
   static Logger log = Logger.getLogger(IbatisUpdate.class.getName());

   public static void main(String[] args)
   throws IOException,SQLException{
      Reader rd = Resources.getResourceAsReader("SqlMapConfig.xml");
      SqlMapClient smc = SqlMapClientBuilder.buildSqlMapClient(rd);

      /* This would insert one record in Employee table. */
      log.info("Going to update record.....");
      Employee rec = new Employee();
      rec.setId(1);
      rec.setFirstName( "Roma");
      smc.update("Employee.update", rec );
      log.info("Record updated Successfully ");

      log.debug("Going to read records.....");
      List <Employee> ems = (List<Employee>) 
         smc.queryForList("Employee.getAll", null);
      Employee em = null;
		
      for (Employee e : ems) {
         System.out.print("  " + e.getId());
         System.out.print("  " + e.getFirstName());
         System.out.print("  " + e.getLastName());
         System.out.print("  " + e.getSalary());
         em = e;
         System.out.println("");
      }
      log.debug("Records Read Successfully ");
   }
}

Compilation et exécution

Tout d'abord, assurez-vous d'avoir correctement défini PATH et CLASSPATH avant de procéder à la compilation et à l'exécution.

  • Créez Employee.xml comme indiqué ci-dessus.
  • Créez Employee.java comme indiqué ci-dessus et compilez-le.
  • Créez IbatisUpdate.java comme indiqué ci-dessus et compilez-le.
  • Créez log4j.properties comme indiqué ci-dessus.
  • Exécutez le binaire IbatisUpdate pour exécuter le programme.

Vous obtiendrez le résultat suivant. Un enregistrement serait mis à jour dans la table EMPLOYEE et plus tard, le même enregistrement serait lu à partir de la table EMPLOYEE.

DEBUG [main] - Created connection 28405330.
DEBUG [main] - Returned connection 28405330 to pool.
DEBUG [main] - Checked out connection 28405330 from pool.
DEBUG [main] - Returned connection 28405330 to pool.
   1  Roma  Ali  5000
   2  Zara  Ali  5000
   3  Zara  Ali  5000

Méthodes de débogage

Dans l'exemple ci-dessus, nous avons utilisé uniquement info() Cependant, vous pouvez utiliser l'une des méthodes suivantes selon vos besoins -

public void trace(Object message);
public void debug(Object message);
public void info(Object message);
public void warn(Object message);
public void error(Object message);
public void fatal(Object message);

Il existe des différences majeures entre iBATIS et Hibernate. Les deux solutions fonctionnent bien, compte tenu de leur domaine spécifique. iBATIS est suggéré dans le cas -

  • Vous voulez créer vos propres SQL et vous êtes prêt à les maintenir.
  • Votre environnement est piloté par un modèle de données relationnel.
  • Vous devez travailler sur des schémas existants et complexes.

Utilisez Hibernate si l'environnement est piloté par un modèle objet et doit générer automatiquement SQL.

Différence entre iBATIS et Hibernate

Hibernate et iBATIS sont des outils de cartographie relationnelle objet (ORM) open source disponibles dans l'industrie. L'utilisation de chacun de ces outils dépend du contexte dans lequel vous les utilisez.

Le tableau suivant met en évidence les différences entre iBATIS et Hibernate -

iBATIS Hiberner
iBATIS est plus simple. Il est livré dans un emballage beaucoup plus petit. Hibernate génère du SQL pour vous, ce qui signifie que vous n'avez pas à passer du temps à générer du SQL.
iBATIS est flexible. Il offre un temps de développement plus rapide. Hibernate est hautement évolutif. Il fournit un cache beaucoup plus avancé.
iBATIS utilise SQL qui peut dépendre de la base de données. Hibernate utilise HQL qui est relativement indépendant des bases de données. Il est plus facile de changer de base de données dans Hibernate.
iBatis mappe le ResultSet de l'API JDBC à vos objets POJO, vous n'avez donc pas à vous soucier des structures de table. Hibernate mappe vos objets Java POJO aux tables de la base de données.
Il est assez facile d'utiliser la procédure stockée dans iBATIS. L'utilisation de procédures stockées est un peu difficile dans Hibernate.

Hibernate et iBATIS reçoivent tous deux un bon support du framework SPRING, il ne devrait donc pas être un problème de choisir l'un d'entre eux.

iBATOR est un générateur de code pour iBATIS. iBATOR introspecte une ou plusieurs tables de base de données et génère des artefacts iBATIS qui peuvent être utilisés pour accéder aux tables.

Plus tard, vous pouvez écrire votre code SQL personnalisé ou votre procédure stockée pour répondre à vos besoins. iBATOR génère les artefacts suivants -

  • Fichiers XML SqlMap
  • Classes Java pour correspondre à la clé primaire et aux champs de la ou des tables
  • Classes DAO qui utilisent les objets ci-dessus (facultatif)

iBATOR peut s'exécuter en tant que fichier JAR autonome, ou en tant que tâche Ant, ou en tant que plugin Eclipse. Ce didacticiel décrit la manière la plus simple de générer des fichiers de configuration iBATIS à partir de la ligne de commande.

Télécharger iBATOR

Téléchargez le JAR autonome si vous utilisez un IDE autre qu'Eclipse. Le JAR autonome comprend une tâche Ant pour exécuter iBATOR, ou vous pouvez exécuter iBATOR à partir de la ligne de commande du code Java.

  • Vous pouvez télécharger un fichier zip à partir de Download iBATOR .

  • Vous pouvez consulter la documentation en ligne - iBATOR Documentation .

Génération du fichier de configuration

Pour exécuter iBATOR, procédez comme suit:

Étape 1

Créez et remplissez un fichier de configuration ibatorConfig.xml de manière appropriée. Au minimum, vous devez spécifier -

  • UNE <jdbcConnection> élément pour spécifier comment se connecter à la base de données cible.

  • UNE <javaModelGenerator> élément pour spécifier le package cible et le projet cible pour les objets de modèle Java générés.

  • UNE <sqlMapGenerator> élément pour spécifier le package cible et le projet cible pour les fichiers de mappage SQL générés.

  • UNE <daoGenerator> pour spécifier le package cible et le projet cible pour les interfaces et classes DAO générées (vous pouvez omettre l'élément <daoGenerator> si vous ne souhaitez pas générer des DAO).

  • Au moins une base de données <table> élément

NOTE −Consultez la page de référence du fichier de configuration XML pour un exemple de fichier de configuration iBATOR.

Étape 2

Enregistrez le fichier dans un emplacement pratique, par exemple à l'adresse: \ temp \ ibatorConfig.xml.

Étape 3

Maintenant, exécutez iBATOR à partir de la ligne de commande comme suit -

java -jar abator.jar -configfile \temp\abatorConfig.xml -overwrite

Il indiquera à iBATOR de s'exécuter en utilisant votre fichier de configuration. Il indiquera également à iBATOR d'écraser tous les fichiers Java existants portant le même nom. Si vous souhaitez enregistrer des fichiers Java existants, omettez le−overwrite paramètre.

En cas de conflit, iBATOR enregistre le fichier nouvellement généré sous un nom unique.

Après avoir exécuté iBATOR, vous devez créer ou modifier les fichiers de configuration iBATIS standard pour utiliser votre code nouvellement généré. Ceci est expliqué dans la section suivante.

Tâches après l'exécution d'iBATOR

Après avoir exécuté iBATOR, vous devez créer ou modifier d'autres artefacts de configuration iBATIS. Les principales tâches sont les suivantes -

  • Créez ou modifiez le fichier SqlMapConfig.xml.
  • Créez ou modifiez le fichier dao.xml (uniquement si vous utilisez iBATIS DAO Framework).

Chaque tâche est décrite en détail ci-dessous -

Mise à jour du fichier SqlMapConfig.xml

iBATIS utilise un fichier XML, communément appelé SqlMapConfig.xml, pour spécifier des informations pour une connexion à une base de données, un schéma de gestion des transactions et des fichiers XML de mappage SQL utilisés dans une session iBATIS.

iBATOR ne peut pas créer ce fichier pour vous car il ne sait rien de votre environnement d'exécution. Cependant, certains des éléments de ce fichier sont directement liés aux éléments générés par iBATOR.

Les besoins spécifiques d'iBATOR dans le fichier de configuration sont les suivants -

  • Les espaces de noms d'instructions doivent être activés.
  • Les fichiers XML SQL Map générés par iBATOR doivent être répertoriés.

Par exemple, supposons qu'iBATOR a généré un fichier XML SQL Map appelé MyTable_SqlMap.xml et que le fichier a été placé dans le package test.xml de votre projet. Le fichier SqlMapConfig.xml doit avoir ces entrées -

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE sqlMapConfig PUBLIC "-//ibatis.apache.org//DTD SQL Map Config 2.0//EN" "http://ibatis.apache.org/dtd/sql-map-config-2.dtd">

<sqlMapConfig>
   <!-- Statement namespaces are required for Abator -->
   <settings useStatementNamespaces="true" />

   <!-- Setup the transaction manager and data source that are
   appropriate for your environment
   -->
	
   <transactionManager type="...">
      <dataSource type="...">
      </dataSource>
   </transactionManager>

   <!-- SQL Map XML files should be listed here -->
   <sqlMap resource="test/xml/MyTable_SqlMap.xml" />

</sqlMapConfig>

S'il y a plus d'un fichier XML SQL Map (comme c'est assez courant), les fichiers peuvent être répertoriés dans n'importe quel ordre avec des éléments <sqlMap> répétés après l'élément <transactionManager>.

Mise à jour du fichier dao.xml

Le framework iBATIS DAO est configuré par un fichier xml communément appelé dao.xml.

La structure iBATIS DAO utilise ce fichier pour contrôler les informations de connexion à la base de données pour les DAO, ainsi que pour répertorier les classes d'implémentation DAO et les interfaces DAO.

Dans ce fichier, vous devez spécifier le chemin d'accès à votre fichier SqlMapConfig.xml et à toutes les interfaces DAO et classes d'implémentation générées par iBATOR.

Par exemple, supposons qu'iBATOR ait généré une interface DAO appelée MyTableDAO et une classe d'implémentation appelée MyTableDAOImpl, et que les fichiers ont été placés dans le package test.dao de votre projet.

Le fichier dao.xml doit avoir ces entrées -

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE daoConfig PUBLIC "-//ibatis.apache.org//DTD DAO Configuration 2.0//EN" "http://ibatis.apache.org/dtd/dao-2.dtd">

<daoConfig>

   <context>
	
      <transactionManager type="SQLMAP">
         <property name="SqlMapConfigResource" value="test/SqlMapConfig.xml"/>
      </transactionManager>

      <!-- DAO interfaces and implementations should be listed here -->
      <dao interface="test.dao.MyTableDAO" implementation="test.dao.MyTableDAOImpl" />
   </context>
	
</daoConfig>

NOTE − Cette étape n'est requise que si vous avez généré des DAO pour le framework iBATIS DAO.