iBATIS - ऑपरेशन पढ़ें

हमने चर्चा की, आखिरी अध्याय में, iBATIS का उपयोग करके टेबल पर क्रिएट ऑपरेशन कैसे करें। यह अध्याय बताता है कि iBATIS का उपयोग करके तालिका कैसे पढ़ें।

हमारे पास MySQL में निम्न 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)
);

इस तालिका में केवल एक रिकॉर्ड निम्नानुसार है -

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

कर्मचारी POJO वर्ग

रीड ऑपरेशन करने के लिए, हम Employee.java में कर्मचारी वर्ग को संशोधित करेंगे -

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

Employee.xml फ़ाइल

IBATIS का उपयोग करते हुए SQL मैपिंग स्टेटमेंट को परिभाषित करने के लिए, हम Employee.xml फ़ाइल में <select> टैग जोड़ेंगे और इस टैग परिभाषा के अंदर, हम एक "id" को परिभाषित करेंगे जिसका उपयोग डेटाबेस पर SQL SELECT क्वेरी को निष्पादित करने के लिए IbatisRead.java फ़ाइल में किया जाएगा।

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

यहां हमने SQL SELECT स्टेटमेंट के साथ WHERE क्लॉज का उपयोग नहीं किया। हम अगले अध्याय में प्रदर्शित करेंगे कि आप सेलेक्ट स्टेटमेंट के साथ WHERE क्लॉज का उपयोग कैसे कर सकते हैं और आप उस WHO क्लॉज को मान कैसे दे सकते हैं।

IbatisRead.java फ़ाइल

इस फ़ाइल में कर्मचारी स्तर से रिकॉर्ड पढ़ने के लिए आवेदन स्तर तर्क है -

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

संकलन और भागो

उपर्युक्त सॉफ्टवेयर को संकलित करने और चलाने के लिए यहां चरण दिए गए हैं। सुनिश्चित करें कि आपने संकलन और निष्पादन के लिए आगे बढ़ने से पहले PATH और CLASSPATH को उचित रूप से सेट किया है।

  • जैसा कि ऊपर दिखाया गया है Employee.xml बनाएं।
  • जैसा कि ऊपर दिखाया गया है, Employee.java बनाएं और इसे संकलित करें।
  • जैसा कि ऊपर दिखाया गया है और इसे संकलित करें।
  • कार्यक्रम को चलाने के लिए इबैटिसराइड बाइनरी निष्पादित करें।

आपको निम्न परिणाम मिलेगा, और एक रिकॉर्ड EMPLOYEE तालिका से निम्नानुसार पढ़ा जाएगा -

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