2.1 टेबल लेवल पर लिंकिंग

हमने देखा है कि कैसे हाइबरनेट संग्रह को सहायक तालिकाओं में संग्रहीत करता है। अब आइए जानें कि वास्तविक इकाई वर्गों को संग्रहीत करने वाली पूर्ण तालिकाओं के बीच संबंधों को कैसे व्यवस्थित किया जाए।

हाइबरनेट में इकाई वर्गों के बीच चार प्रकार के संबंध हैं:

  • एक -से- एक
  • एक से अनेक
  • कई -से- एक
  • कई -से- कई

और हम विश्लेषण की शुरुआत सरलतम विकल्प - अनेक -से- एक के साथ करेंगे ।

आप SQL में टेबल के बीच इस तरह के संबंध के बारे में पहले ही जान चुके हैं। यहाँ यह आमतौर पर कैसा दिखता है:

पहचान नाम पेशा वेतन आयु शामिल होने की तारीख
1 इवानोव इवान प्रोग्रामर 100000 25 2012-06-30
2 पेट्रोव पेट्र प्रोग्रामर 80000 23 2013-08-12
3 इवानोव सर्गेई टेस्टर 40000 तीस 2014-01-01
4 राबिनोविच मोइशा निदेशक 200000 35 2015-05-12
5 किरिंको अनास्तासिया कार्यालय प्रबंधक 40000 25 2015-10-10
6 वास्का बिल्ली 1000 3 2018-11-11

कर्मचारी तालिका:

इस तालिका में निम्नलिखित स्तंभ हैं:

  • आईडी आईएनटी
  • वचरर नाम
  • व्यवसाय VARCHAR
  • वेतन आई.टी
  • आयु आई.टी
  • join_date DATE

और इस प्रकार कार्य तालिका , जिसमें कर्मचारियों के लिए कार्य शामिल हैं, ऐसा दिखता है:

पहचान कर्मचारी आयडी नाम अंतिम तारीख
1 1 दृश्यपटल पर एक बग ठीक करें 2022-06-01
2 2 बैकएंड पर एक बग ठीक करें 2022-06-15
3 5 कॉफी खरीदें 2022-07-01
4 5 कॉफी खरीदें 2022-08-01
5 5 कॉफी खरीदें 2022-09-01
6 (व्यर्थ) कार्यालय की सफाई करें (व्यर्थ)
7 4 जीवन का आनंद लें (व्यर्थ)
8 6 जीवन का आनंद लें (व्यर्थ)

इस तालिका में केवल 4 स्तंभ हैं:

  • आईडी - अद्वितीय कार्य संख्या (और तालिका में पंक्तियाँ);
  • कर्मचारी_आईडी - कर्मचारी तालिका से कर्मचारी आईडी जिसे कार्य सौंपा गया है;
  • नाम - कार्य का नाम और विवरण;
  • समय सीमा - वह समय जिसके द्वारा कार्य पूरा किया जाना चाहिए।

हम देखते हैं कि कार्य तालिका में कई पंक्तियाँ कर्मचारी तालिका में एकल प्रविष्टि को संदर्भित कर सकती हैं। इस तरह के टेबल-लेवल रिलेशनशिप को मैनी-टू -वन कहा जाता है।

2.2 जावा वर्ग स्तर से संबंध

तालिका स्तर पर संचार के अतिरिक्त, आप हाइबरनेट में इकाई कक्षाओं के स्तर पर भी संचार व्यवस्थित कर सकते हैं। यह एक एनोटेशन के साथ किया जाता है @ManyToOne

लेकिन पहले, आइए केवल दो वर्ग बनाएँ: कर्मचारी और कर्मचारी कार्य :


@Entity
@Table(name="employee")
class Employee {
   @Column(name="id")
   public Integer id;
 
   @Column(name="name")
   public String name;
 
   @Column(name="occupation")
   public String occupation;
 
   @Column(name="salary")
   public Integer salary;
 
   @Column(name="join_date")
   public Date join;
}

और कर्मचारी नौकरियों को स्टोर करने के लिए दूसरी श्रेणी:


@Entity
@Table(name="task")
class EmployeeTask {
   @Column(name="id")
   public Integer id;
 
   @Column(name="name")
   public String description;
 
  @Column(name="employee_id")
   public Integer employeeId;
 
   @Column(name="deadline")
   public Date deadline;
}

इन वर्गों के साथ सब ठीक है, लेकिन उनके बीच कोई संबंध नहीं है जो इस तथ्य को दर्शाता है कि कर्मचारी कार्य वर्ग का कर्मचारी आईडी क्षेत्र कर्मचारी वर्ग के आईडी क्षेत्र को संदर्भित करता है। इसे ठीक करने का समय आ गया है

2.3 @ManyToOne एनोटेशन।

सबसे पहले, जावा में हम उनकी आईडी के बजाय ऑब्जेक्ट्स (और ऑब्जेक्ट रेफरेंस) पर काम करने के आदी हैं। तो सबसे पहले, EmployeeTask वर्ग में कर्मचारी आईडी फ़ील्ड के बजाय, कर्मचारी प्रकार के ऑब्जेक्ट को इंगित करें। यहाँ हमारी नई कक्षा कैसी दिखेगी:


@Entity
@Table(name="task")
class EmployeeTask {
   @Column(name="id")
   public Integer id;
 
   @Column(name="name")
   public String description;
 
   @ManyToOne
   @JoinColumn(name = "employee_id")
   public Employee employee;
 
   @Column(name="deadline")
   public Date deadline;
}

एनोटेशन की मदद से @ManyToOne, हमने संकेत दिया है कि कई एंप्लॉयी टास्क ऑब्जेक्ट्स एक प्रकार के कर्मचारी के एक ऑब्जेक्ट को संदर्भित कर सकते हैं। इसके अलावा, एनोटेशन का @JoinColumn उपयोग करते हुए , हमने संकेत दिया कि हमारी तालिका के किस कॉलम में कर्मचारी वस्तु की आईडी संग्रहीत है।

2.4 अनुरोध उदाहरण

और अब कुछ उदाहरण दिखाते हैं कि हाइबरनेट ऐसे संबंधित वर्गों के साथ कैसे काम कर सकता है।

परिदृश्य एक

आइए एक विशिष्ट उपयोगकर्ता को सौंपे गए सभी कार्यों का पता लगाने के लिए एक प्रश्न लिखें। यह क्वेरी एचक्यूएल में कैसी दिखेगी:

from EmployeeTask where employee.name = "Ivan Ivanovich"

आप केवल डॉट के माध्यम से निर्भर वर्गों के क्षेत्रों का उल्लेख कर सकते हैं। यह बहुत आरामदायक है। लेकिन चलिए फिर भी इस क्वेरी को जावा कोड के रूप में लिखते हैं:


String hql = "from EmployeeTask where employee.name = :username";
Query<EmployeeTask> query = session.createQuery( hql, EmployeeTask.class);
query.setParameter("username", "Ivan Ivanovich");
List<EmployeeTask> resultLIst = query.list();

परिदृश्य दो

आइए एक क्वेरी लिखें जो उन कर्मचारियों की सूची लौटाती है जिनके पास अतिदेय कार्य हैं। एक कार्य अतिदेय है यदि इसकी समय सीमा अतीत में है। यहाँ वह क्वेरी SQL में कैसी दिखेगी:


SELECT DISTINCT employee.*
FROM task JOIN employee ON task.employee_id = employee.id
WHERE task.deadline < CURDATE();

DISTINCTउपयोग किया जाता है क्योंकि एक उपयोगकर्ता को कई कार्य सौंपे जा सकते हैं।

और अब उसी प्रश्न को HQL में लिखते हैं:

select distinct employee from EmployeeTask where deadline < CURDATE();

इस प्रश्न में कर्मचारी कर्मचारी कार्य वर्ग का एक क्षेत्र है

स्थिति तीन

सभी अनिर्दिष्ट कार्यों को निदेशक को सौंपें। SQL क्वेरी इस तरह दिखेगी:


UPDATE task SET employee_id = 4 WHERE employee_id IS NULL

और अब उसी प्रश्न को HQL में लिखते हैं:

update EmployeeTask set employee = :user where employee is null

अंतिम प्रश्न सबसे कठिन है। हमें निदेशक की आईडी पास करने की आवश्यकता है, लेकिन एम्प्लॉईटास्क क्लास में एक फ़ील्ड नहीं है जहां हम एक आईडी लिख सकते हैं, इसके बजाय इसमें एक कर्मचारी फ़ील्ड होता है जहां हमें कर्मचारी प्रकार के ऑब्जेक्ट का संदर्भ देने की आवश्यकता होती है।


Employee director = session.get(Employee.class, 4);
 
String hql = "update EmployeeTask set employee = :user where employee is null";
Query<EmployeeTask> query = session.createQuery(hql, EmployeeTask.class);
query.setParameter("user", director);
query.executeUpdate();