iBATIS - ऑपरेशन बनाएँ
IBATIS का उपयोग करके कोई भी क्रिएट, रीड, अपडेट और डिलीट (CRUD) ऑपरेशन करने के लिए, आपको टेबल के अनुरूप प्लेन ओल्ड जावा ऑब्जेक्ट (POJO) क्लास बनाना होगा। यह वर्ग उन वस्तुओं का वर्णन करता है जो डेटाबेस तालिका पंक्तियों को "मॉडल" करेंगे।
POJO वर्ग वांछित संचालन करने के लिए आवश्यक सभी तरीकों के लिए कार्यान्वयन होगा।
मान लें कि हमारे पास 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)
);
कर्मचारी 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;
}
} /* End of Employee */
आप तालिका में अलग-अलग फ़ील्ड सेट करने के तरीकों को परिभाषित कर सकते हैं। अगला अध्याय बताता है कि व्यक्तिगत क्षेत्रों के मूल्यों को कैसे प्राप्त किया जाए।
Employee.xml फ़ाइल
IBATIS का उपयोग करते हुए SQL मैपिंग स्टेटमेंट को परिभाषित करने के लिए, हम <Insert> टैग का उपयोग करेंगे और इस टैग परिभाषा के अंदर, हम एक "id" को परिभाषित करेंगे जिसका उपयोग डेटाबेस पर SQL INSERT क्वेरी को निष्पादित करने के लिए IbatisInsert.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>
</sqlMap>
यहाँ parameterClass −स्ट्रिंग, इंट, फ्लोट, डबल या आवश्यकता के आधार पर किसी भी क्लास ऑब्जेक्ट के रूप में मान ले सकता है । इस उदाहरण में, हम SqlMap वर्ग के सम्मिलित विधि को कॉल करते समय एक पैरामीटर के रूप में कर्मचारी वस्तु को पारित करेंगे ।
यदि आपकी डेटाबेस तालिका एक पहचान, AUTO_INCREMENT, या सीरियल कॉलम का उपयोग करती है या आपने एक SEQUENCE / जनरेटर को परिभाषित किया है, तो आप डेटाबेस-जनरक्षित मान का उपयोग या वापस करने के लिए <selectKey> तत्व का उपयोग कर सकते हैं।
IbatisInsert.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 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 ");
}
}
संकलन और भागो
उपर्युक्त सॉफ्टवेयर को संकलित करने और चलाने के लिए यहां चरण दिए गए हैं। सुनिश्चित करें कि आपने संकलन और निष्पादन के लिए आगे बढ़ने से पहले PATH और CLASSPATH को उचित रूप से सेट किया है।
- जैसा कि ऊपर दिखाया गया है Employee.xml बनाएं।
- जैसा कि ऊपर दिखाया गया है, Employee.java बनाएं और इसे संकलित करें।
- जैसा कि ऊपर दिखाया गया है और इसे संकलित करें।
- कार्यक्रम को चलाने के लिए इबैटसइंटर को बाइनरी निष्पादित करें।
आपको निम्न परिणाम मिलेगा, और EMPLOYEE तालिका में एक रिकॉर्ड बनाया जाएगा।
$java IbatisInsert
Going to insert record.....
Record Inserted Successfully
यदि आप EMPLOYEE तालिका की जांच करते हैं, तो उसे निम्न परिणाम प्रदर्शित करना चाहिए -
mysql> select * from EMPLOYEE;
+----+------------+-----------+--------+
| id | first_name | last_name | salary |
+----+------------+-----------+--------+
| 1 | Zara | Ali | 5000 |
+----+------------+-----------+--------+
1 row in set (0.00 sec)