iBATIS - संग्रहीत कार्यविधियाँ
आप iBATIS कॉन्फ़िगरेशन का उपयोग करके संग्रहीत कार्यविधि को कॉल कर सकते हैं। सबसे पहले, हम समझते हैं कि MySQL में एक संग्रहीत कार्यविधि कैसे बनाई जाए।
हमारे पास 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 डेटाबेस में निम्नलिखित संग्रहित प्रक्रिया बनाते हैं -
DELIMITER $$
DROP PROCEDURE IF EXISTS `testdb`.`getEmp` $$
CREATE PROCEDURE `testdb`.`getEmp`
(IN empid INT)
BEGIN
SELECT * FROM EMPLOYEE
WHERE ID = empid;
END $$
DELIMITER;
आइए विचार करें कि ईएमपीएलओईईई तालिका के दो रिकॉर्ड निम्नानुसार हैं -
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)
कर्मचारी 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 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 */
Employee.xml फ़ाइल
यहाँ हम Employee.xml को संशोधित करने के लिए <प्रक्रिया> </ प्रक्रिया> और <पैरामीटरमैप> </ पैरामीटर मैप्स> टैग पेश करेंगे। यहां <प्रक्रिया> </ प्रक्रिया> टैग में एक आईडी होगी जिसका उपयोग हम अपने आवेदन में संग्रहीत प्रक्रिया को कॉल करने के लिए करेंगे।
<?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>
IbatisSP.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 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 ");
}
}
संकलन और भागो
उपर्युक्त सॉफ्टवेयर को संकलित करने और चलाने के लिए यहां चरण दिए गए हैं। सुनिश्चित करें कि आपने संकलन और निष्पादन के लिए आगे बढ़ने से पहले PATH और CLASSPATH को उचित रूप से सेट किया है।
- जैसा कि ऊपर दिखाया गया है Employee.xml बनाएं।
- जैसा कि ऊपर दिखाया गया है, Employee.java बनाएं और इसे संकलित करें।
- जैसा कि ऊपर दिखाया गया है और इसे संकलित करें।
- कार्यक्रम को चलाने के लिए इब्रैटिसपी बाइनरी निष्पादित करें।
आपको निम्न परिणाम मिलेगा -
Going to read employee name.....
First Name: Zara
Record name Successfully