हाइबरनेट - एनोटेशन
अब तक आपने देखा है कि कैसे POJO से डेटाबेस तालिकाओं और इसके विपरीत डेटा के परिवर्तन के लिए हाइबरनेट XML मैपिंग फ़ाइल का उपयोग करता है। हाइबरनेट एनोटेशन XML फ़ाइल के उपयोग के बिना मैपिंग को परिभाषित करने का सबसे नया तरीका है। आप XML मैपिंग मेटाडेटा के प्रतिस्थापन के रूप में या इसके अलावा एनोटेशन का उपयोग कर सकते हैं।
हाइबरनेट एनोटेशन ऑब्जेक्ट और रिलेशनल टेबल मैपिंग के लिए मेटाडेटा प्रदान करने का शक्तिशाली तरीका है। सभी मेटाडेटा को कोड के साथ POJO जावा फ़ाइल में जोड़ा जाता है, इससे उपयोगकर्ता को विकास के दौरान तालिका संरचना और POJO को एक साथ समझने में मदद मिलती है।
यदि आप अन्य EJB 3 आज्ञाकारी ORM अनुप्रयोगों के लिए अपने आवेदन को पोर्टेबल बनाने जा रहे हैं, तो आपको मैपिंग जानकारी का प्रतिनिधित्व करने के लिए एनोटेशन का उपयोग करना होगा, लेकिन फिर भी यदि आप अधिक लचीलापन चाहते हैं, तो आपको XML- आधारित मैपिंग के साथ जाना चाहिए।
हाइबरनेट व्याख्या के लिए पर्यावरण सेटअप
सबसे पहले आपको यह सुनिश्चित करना होगा कि आप JDK 5.0 का उपयोग कर रहे हैं अन्यथा आपको एनोटेशन के लिए मूल समर्थन का लाभ लेने के लिए अपने JDK को JDK 5.0 में अपग्रेड करने की आवश्यकता है।
दूसरा, आपको स्रोत से उपलब्ध हाइबरनेट 3.x एनोटेशन वितरण पैकेज स्थापित करना होगा: ( हाइबरनेट एनोटेशन डाउनलोड करें ) और कॉपी करेंhibernate-annotations.jar, lib/hibernate-comons-annotations.jar तथा lib/ejb3-persistence.jar अपने CLASSPATH को हाइबरनेट एनोटेशन वितरण से।
एनोटेट क्लास उदाहरण
जैसा कि मैंने ऊपर उल्लेख किया है कि हाइबरनेट एनोटेशन के साथ काम करते समय, सभी मेटाडेटा को कोड के साथ POJO जावा फ़ाइल में जोड़ा जाता है, इससे उपयोगकर्ता को विकास के दौरान तालिका संरचना और POJO को एक साथ समझने में मदद मिलती है।
विचार करें कि हम अपनी वस्तुओं को संग्रहीत करने के लिए निम्नलिखित 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)
);
निम्न कर्मचारी वर्ग की मैपिंग के साथ एनोट्लॉई टेबल के साथ परिभाषित मानचित्र के साथ एनोटेशन के साथ मैप करना है -
import javax.persistence.*;
@Entity
@Table(name = "EMPLOYEE")
public class Employee {
@Id @GeneratedValue
@Column(name = "id")
private int id;
@Column(name = "first_name")
private String firstName;
@Column(name = "last_name")
private String lastName;
@Column(name = "salary")
private int salary;
public Employee() {}
public int getId() {
return id;
}
public void setId( int id ) {
this.id = id;
}
public String getFirstName() {
return firstName;
}
public void setFirstName( String first_name ) {
this.firstName = first_name;
}
public String getLastName() {
return lastName;
}
public void setLastName( String last_name ) {
this.lastName = last_name;
}
public int getSalary() {
return salary;
}
public void setSalary( int salary ) {
this.salary = salary;
}
}
हाइबरनेट यह पता लगाता है कि @ आईड एनोटेशन एक क्षेत्र पर है और यह मानता है कि इसे रनटाइम के दौरान खेतों के माध्यम से सीधे किसी वस्तु के गुणों का उपयोग करना चाहिए। यदि आपने getId () विधि पर @Id एनोटेशन रखा है, तो आप डिफ़ॉल्ट रूप से गेट्टर और सेटर विधियों के माध्यम से संपत्तियों तक पहुँच को सक्षम करेंगे। इसलिए, चयनित रणनीति का पालन करते हुए, अन्य सभी एनोटेशन को भी फ़ील्ड्स या गेट्टर विधियों पर रखा जाता है।
निम्नलिखित अनुभाग उपरोक्त वर्ग में उपयोग किए गए एनोटेशन की व्याख्या करेगा।
@Entity एनोटेशन
EJB 3 मानक एनोटेशन में निहित हैं javax.persistenceपैकेज, इसलिए हम इस पैकेज को पहले चरण के रूप में आयात करते हैं। दूसरा, हमने इस्तेमाल किया@Entity कर्मचारी वर्ग को एनोटेशन, जो इस वर्ग को एक इकाई बीन के रूप में चिह्नित करता है, इसलिए इसमें एक नो-लॉजिक कंस्ट्रक्टर होना चाहिए जो कम से कम संरक्षित दायरे के साथ दिखाई दे।
@ स्थिर एनोटेशन
@ सारणीबद्ध एनोटेशन आपको उस तालिका का विवरण निर्दिष्ट करने की अनुमति देता है जिसका उपयोग डेटाबेस में इकाई को बनाए रखने के लिए किया जाएगा।
@ सारणीबद्ध एनोटेशन चार विशेषताएँ प्रदान करता है, जिससे आप तालिका के नाम, उसकी सूची और उसके स्कीमा को ओवरराइड कर सकते हैं, और तालिका में स्तंभों पर अद्वितीय बाधाओं को लागू कर सकते हैं। अभी के लिए, हम सिर्फ टेबल नाम का उपयोग कर रहे हैं, जो कि EMPLOYEE है।
@ आईड और @GeneratedValue एनोटेशन
प्रत्येक इकाई बीन में एक प्राथमिक कुंजी होगी, जिसे आप वर्ग के साथ एनोटेट करते हैं @Idएनोटेशन। प्राथमिक कुंजी आपकी तालिका संरचना के आधार पर एक एकल फ़ील्ड या कई फ़ील्ड्स का संयोजन हो सकती है।
डिफ़ॉल्ट रूप से, @Id एनोटेशन स्वचालित रूप से उपयोग की जाने वाली सबसे उपयुक्त प्राथमिक कुंजी पीढ़ी की रणनीति निर्धारित करेगा, लेकिन आप इसे लागू करके इसे ओवरराइड कर सकते हैं @GeneratedValue एनोटेशन, जो दो मापदंडों को लेता है strategy तथा generatorमैं यहां चर्चा नहीं करने जा रहा हूं, इसलिए हम केवल डिफ़ॉल्ट कुंजी पीढ़ी की रणनीति का उपयोग करें। हाइबरनेट को यह निर्धारित करने दें कि कौन सा जनरेटर प्रकार का उपयोग करना है जो आपके कोड को विभिन्न डेटाबेस के बीच पोर्टेबल बनाता है।
@ कॉलम एनोटेशन
कॉलम के विवरण को निर्दिष्ट करने के लिए @ कॉलम एनोटेशन का उपयोग किया जाता है जिसमें फ़ील्ड या संपत्ति मैप की जाएगी। आप कॉलम एनोटेशन का उपयोग निम्नलिखित सबसे अधिक इस्तेमाल की जाने वाली विशेषताओं के साथ कर सकते हैं -
name विशेषता स्तंभ के नाम को स्पष्ट रूप से निर्दिष्ट करने की अनुमति देती है।
length विशेषता विशेष रूप से स्ट्रिंग मान के लिए किसी मान को मैप करने के लिए उपयोग किए गए स्तंभ के आकार की अनुमति देती है।
nullable विशेषता स्कीम उत्पन्न होने पर कॉलम को NULL के रूप में चिह्नित करने की अनुमति देता है।
unique विशेषता स्तंभ को केवल अनन्य मानों के रूप में चिह्नित करने की अनुमति देती है।
एप्लिकेशन क्लास बनाएं
अंत में, हम एप्लिकेशन को चलाने के लिए मुख्य () पद्धति से अपना एप्लिकेशन क्लास बनाएंगे। हम इस एप्लिकेशन का उपयोग कुछ कर्मचारियों के रिकॉर्ड को बचाने के लिए करेंगे और फिर हम उन रिकॉर्ड्स पर CRUD ऑपरेशन लागू करेंगे।
import java.util.List;
import java.util.Date;
import java.util.Iterator;
import org.hibernate.HibernateException;
import org.hibernate.Session;
import org.hibernate.Transaction;
import org.hibernate.cfg.AnnotationConfiguration;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;
public class ManageEmployee {
private static SessionFactory factory;
public static void main(String[] args) {
try {
factory = new AnnotationConfiguration().
configure().
//addPackage("com.xyz") //add package if used.
addAnnotatedClass(Employee.class).
buildSessionFactory();
} catch (Throwable ex) {
System.err.println("Failed to create sessionFactory object." + ex);
throw new ExceptionInInitializerError(ex);
}
ManageEmployee ME = new ManageEmployee();
/* Add few employee records in database */
Integer empID1 = ME.addEmployee("Zara", "Ali", 1000);
Integer empID2 = ME.addEmployee("Daisy", "Das", 5000);
Integer empID3 = ME.addEmployee("John", "Paul", 10000);
/* List down all the employees */
ME.listEmployees();
/* Update employee's records */
ME.updateEmployee(empID1, 5000);
/* Delete an employee from the database */
ME.deleteEmployee(empID2);
/* List down new list of the employees */
ME.listEmployees();
}
/* Method to CREATE an employee in the database */
public Integer addEmployee(String fname, String lname, int salary){
Session session = factory.openSession();
Transaction tx = null;
Integer employeeID = null;
try {
tx = session.beginTransaction();
Employee employee = new Employee();
employee.setFirstName(fname);
employee.setLastName(lname);
employee.setSalary(salary);
employeeID = (Integer) session.save(employee);
tx.commit();
} catch (HibernateException e) {
if (tx!=null) tx.rollback();
e.printStackTrace();
} finally {
session.close();
}
return employeeID;
}
/* Method to READ all the employees */
public void listEmployees( ){
Session session = factory.openSession();
Transaction tx = null;
try {
tx = session.beginTransaction();
List employees = session.createQuery("FROM Employee").list();
for (Iterator iterator = employees.iterator(); iterator.hasNext();){
Employee employee = (Employee) iterator.next();
System.out.print("First Name: " + employee.getFirstName());
System.out.print(" Last Name: " + employee.getLastName());
System.out.println(" Salary: " + employee.getSalary());
}
tx.commit();
} catch (HibernateException e) {
if (tx!=null) tx.rollback();
e.printStackTrace();
} finally {
session.close();
}
}
/* Method to UPDATE salary for an employee */
public void updateEmployee(Integer EmployeeID, int salary ){
Session session = factory.openSession();
Transaction tx = null;
try {
tx = session.beginTransaction();
Employee employee = (Employee)session.get(Employee.class, EmployeeID);
employee.setSalary( salary );
session.update(employee);
tx.commit();
} catch (HibernateException e) {
if (tx!=null) tx.rollback();
e.printStackTrace();
} finally {
session.close();
}
}
/* Method to DELETE an employee from the records */
public void deleteEmployee(Integer EmployeeID){
Session session = factory.openSession();
Transaction tx = null;
try {
tx = session.beginTransaction();
Employee employee = (Employee)session.get(Employee.class, EmployeeID);
session.delete(employee);
tx.commit();
} catch (HibernateException e) {
if (tx!=null) tx.rollback();
e.printStackTrace();
} finally {
session.close();
}
}
}
डेटाबेस कॉन्फ़िगरेशन
अब हम बनाते हैं hibernate.cfg.xml डेटाबेस संबंधित मापदंडों को परिभाषित करने के लिए कॉन्फ़िगरेशन फ़ाइल।
<?xml version = "1.0" encoding = "utf-8"?>
<!DOCTYPE hibernate-configuration SYSTEM
"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<session-factory>
<property name = "hibernate.dialect">
org.hibernate.dialect.MySQLDialect
</property>
<property name = "hibernate.connection.driver_class">
com.mysql.jdbc.Driver
</property>
<!-- Assume students is the database name -->
<property name = "hibernate.connection.url">
jdbc:mysql://localhost/test
</property>
<property name = "hibernate.connection.username">
root
</property>
<property name = "hibernate.connection.password">
cohondob
</property>
</session-factory>
</hibernate-configuration>
संकलन और निष्पादन
उपर्युक्त आवेदन को संकलित करने और चलाने के लिए यहां चरण दिए गए हैं। सुनिश्चित करें, आपने संकलन और निष्पादन के लिए आगे बढ़ने से पहले उचित रूप से पथ और क्लास सेट किया है।
पथ से Employee.hbm.xml मैपिंग फ़ाइल हटाएं।
ऊपर दिखाए अनुसार Employee.java स्रोत फ़ाइल बनाएँ और इसे संकलित करें।
जैसा कि ऊपर दिखाया गया है, ManageEmployee.java स्रोत फ़ाइल बनाएं और इसे संकलित करें।
प्रोग्राम को चलाने के लिए ManageEmployee बाइनरी निष्पादित करें।
आपको निम्न परिणाम मिलेगा, और रिकॉर्ड EMPLOYEE तालिका में बनाए जाएंगे।
$java ManageEmployee
.......VARIOUS LOG MESSAGES WILL DISPLAY HERE........
First Name: Zara Last Name: Ali Salary: 1000
First Name: Daisy Last Name: Das Salary: 5000
First Name: John Last Name: Paul Salary: 10000
First Name: Zara Last Name: Ali Salary: 5000
First Name: John Last Name: Paul Salary: 10000
यदि आप अपनी EMPLOYEE तालिका की जांच करते हैं, तो इसके निम्नलिखित रिकॉर्ड होने चाहिए -
mysql> select * from EMPLOYEE;
+----+------------+-----------+--------+
| id | first_name | last_name | salary |
+----+------------+-----------+--------+
| 29 | Zara | Ali | 5000 |
| 31 | John | Paul | 10000 |
+----+------------+-----------+--------+
2 rows in set (0.00 sec
mysql>