iBATIS - Operazione di lettura

Abbiamo discusso, nell'ultimo capitolo, come eseguire l'operazione CREATE su una tabella utilizzando iBATIS. Questo capitolo spiega come leggere una tabella utilizzando iBATIS.

Abbiamo la seguente tabella EMPLOYEE in 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)
);

Questa tabella ha un solo record come segue:

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

Classe POJO dipendente

Per eseguire l'operazione di lettura, modificheremo la classe Employee in Employee.java come segue:

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 */

File Employee.xml

Per definire l'istruzione di mappatura SQL utilizzando iBATIS, aggiungeremo il tag <select> nel file Employee.xml e all'interno di questa definizione di tag, definiremo un "id" che verrà utilizzato nel file IbatisRead.java per eseguire la query SQL SELECT sul database.

<?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>

Qui non abbiamo utilizzato la clausola WHERE con l'istruzione SQL SELECT. Dimostreremo, nel prossimo capitolo, come utilizzare la clausola WHERE con l'istruzione SELECT e come passare valori a quella clausola WHERE.

File IbatisRead.java

Questo file ha una logica a livello di applicazione per leggere i record dalla tabella 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 ");
   }
}

Compilazione ed esecuzione

Ecco i passaggi per compilare ed eseguire il software sopra menzionato. Assicurati di aver impostato PATH e CLASSPATH in modo appropriato prima di procedere con la compilazione e l'esecuzione.

  • Crea Employee.xml come mostrato sopra.
  • Crea Employee.java come mostrato sopra e compilarlo.
  • Crea IbatisRead.java come mostrato sopra e compilarlo.
  • Esegui il binario IbatisRead per eseguire il programma.

Otterrai il seguente risultato e un record verrà letto dalla tabella EMPLOYEE come segue:

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