जेपीए - जेपीक्यूएल
यह अध्याय आपको JPQL के बारे में बताता है और यह दृढ़ता इकाइयों के साथ कैसे काम करता है। इस अध्याय में, उदाहरण उसी पैकेज पदानुक्रम का अनुसरण करते हैं, जिसका उपयोग हमने पिछले अध्याय में निम्नानुसार किया था:
जावा दृढ़ता क्वेरी भाषा
JPQL जावा पर्सिस्टेंस क्वेरी लैंग्वेज है जिसे JPA विनिर्देशन में परिभाषित किया गया है। इसका उपयोग किसी रिलेशनल डेटाबेस में संग्रहीत करने के लिए संस्थाओं के खिलाफ क्वेरी बनाने के लिए किया जाता है। JPQL SQL सिंटैक्स पर आधारित विकसित किया गया है। लेकिन यह सीधे डेटाबेस को प्रभावित नहीं करेगा।
JPQL सेलेक्ट क्लॉज का उपयोग करके जानकारी या डेटा प्राप्त कर सकता है, UPDATE क्लॉज और DELETE क्लॉज का उपयोग करके बल्क अपडेट कर सकता है। EntityManager.createQuery () API भाषा के क्वेरी के लिए समर्थन करेगा।
क्वेरी संरचना
JPQL सिंटैक्स SQL के सिंटैक्स के समान है। एसक्यूएल की तरह सिंटैक्स होना एक फायदा है क्योंकि एसक्यूएल एक सरल संरचित क्वेरी भाषा है और कई डेवलपर्स अनुप्रयोगों में इसका उपयोग कर रहे हैं। SQL सीधे रिलेशनल डेटाबेस टेबल, रिकॉर्ड और फील्ड के विरुद्ध काम करता है, जबकि JPQL जावा क्लासेस और इंस्टेंसेस के साथ काम करता है।
उदाहरण के लिए, एक JPQL क्वेरी SQL के साथ के रूप में डेटाबेस से निर्धारित क्षेत्र परिणाम के बजाय एक इकाई वस्तु प्राप्त कर सकते हैं। JPQL क्वेरी संरचना निम्नानुसार है।
SELECT ... FROM ...
[WHERE ...]
[GROUP BY ... [HAVING ...]]
[ORDER BY ...]
JPQL DELETE और UPDATE प्रश्नों की संरचना इस प्रकार सरल है।
DELETE FROM ... [WHERE ...]
UPDATE ... SET ... [WHERE ...]
स्केलर और सकल कार्य
स्केलर फ़ंक्शन इनपुट मानों के आधार पर परिणामी मान लौटाता है। एग्रीगेट फ़ंक्शन इनपुट मानों की गणना करके परिणामी मान लौटाता है।
पिछले अध्यायों में इस्तेमाल किए गए एक ही उदाहरण कर्मचारी प्रबंधन का पालन करें। यहां हम JPQL के स्केलर और एग्रीगेट कार्यों का उपयोग करके सेवा वर्गों के माध्यम से जाएंगे।
हमें मान लें कि jpadb.employee तालिका में निम्नलिखित रिकॉर्ड हैं।
ईद | Ename | वेतन | डिग्री |
---|---|---|---|
1201 | गोपाल | 40000 | तकनीक प्रबंधक |
1202 | मनीषा | 40000 | प्रमाण पाठक |
1203 | Masthanvali | 40000 | तकनीकी लेखक |
1204 | सतीश | 30000 | तकनीकी लेखक |
1205 | कृष्णा | 30000 | तकनीकी लेखक |
1206 | किरण | 35000 | प्रमाण पाठक |
नाम से एक क्लास बनाएं ScalarandAggregateFunctions.java के अंतर्गत com.tutorialspoint.eclipselink.service पैकेज निम्नानुसार है।
package com.tutorialspoint.eclipselink.service;
import java.util.List;
import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.Persistence;
import javax.persistence.Query;
public class ScalarandAggregateFunctions {
public static void main( String[ ] args ) {
EntityManagerFactory emfactory = Persistence.createEntityManagerFactory( "Eclipselink_JPA" );
EntityManager entitymanager = emfactory.createEntityManager();
//Scalar function
Query query = entitymanager.
createQuery("Select UPPER(e.ename) from Employee e");
List<String> list = query.getResultList();
for(String e:list) {
System.out.println("Employee NAME :"+e);
}
//Aggregate function
Query query1 = entitymanager.createQuery("Select MAX(e.salary) from Employee e");
Double result = (Double) query1.getSingleResult();
System.out.println("Max Employee Salary :" + result);
}
}
उपरोक्त कार्यक्रम के संकलन और निष्पादन के बाद आपको ग्रहण आईडीई के कंसोल पैनल में आउटपुट निम्नानुसार मिलेगा:
Employee NAME :GOPAL
Employee NAME :MANISHA
Employee NAME :MASTHANVALI
Employee NAME :SATISH
Employee NAME :KRISHNA
Employee NAME :KIRAN
ax Employee Salary :40000.0
के बीच, और, कीवर्ड की तरह
'बीच', 'और' और 'लाइक' जेपीक्यूएल के मुख्य कीवर्ड हैं। इन कीवर्ड्स का उपयोग क्वेरी में क्लॉज़ के बाद किया जाता है।
नाम से एक क्लास बनाएं BetweenAndLikeFunctions.java के अंतर्गत com.tutorialspoint.eclipselink.service पैकेज निम्नानुसार है:
package com.tutorialspoint.eclipselink.service;
import java.util.List;
import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.Persistence;
import javax.persistence.Query;
import com.tutorialspoint.eclipselink.entity.Employee;
public class BetweenAndLikeFunctions {
public static void main( String[ ] args ) {
EntityManagerFactory emfactory = Persistence.createEntityManagerFactory( "Eclipselink_JPA" );
EntityManager entitymanager = emfactory.createEntityManager();
//Between
Query query = entitymanager.createQuery( "Select e " + "from Employee e " + "where e.salary " + "Between 30000 and 40000" );
List<Employee> list=(List<Employee>)query.getResultList( );
for( Employee e:list ){
System.out.print("Employee ID :" + e.getEid( ));
System.out.println("\t Employee salary :" + e.getSalary( ));
}
//Like
Query query1 = entitymanager.createQuery("Select e " + "from Employee e " + "where e.ename LIKE 'M%'");
List<Employee> list1=(List<Employee>)query1.getResultList( );
for( Employee e:list1 ) {
System.out.print("Employee ID :"+e.getEid( ));
System.out.println("\t Employee name :"+e.getEname( ));
}
}
}
उपरोक्त कार्यक्रम के संकलन और निष्पादन के बाद आपको ग्रहण आईडीई के कंसोल पैनल में आउटपुट निम्नानुसार मिलेगा:
Employee ID :1201 Employee salary :40000.0
Employee ID :1202 Employee salary :40000.0
Employee ID :1203 Employee salary :40000.0
Employee ID :1204 Employee salary :30000.0
Employee ID :1205 Employee salary :30000.0
Employee ID :1206 Employee salary :35000.0
Employee ID :1202 Employee name :Manisha
Employee ID :1203 Employee name :Masthanvali
आदेश
JPQL में रिकॉर्ड ऑर्डर करने के लिए हम ORDER BY क्लॉज का उपयोग करते हैं। इस खंड का उपयोग SQL में उपयोग के समान है, लेकिन यह संस्थाओं से संबंधित है। उदाहरण द्वारा आदेश का पालन करें।
के तहत एक वर्ग Ordering.java बनाएँ com.tutorialspoint.eclipselink.service पैकेज निम्नानुसार है:
package com.tutorialspoint.eclipselink.service;
import java.util.List;
import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.Persistence;
import javax.persistence.Query;
import com.tutorialspoint.eclipselink.entity.Employee;
public class Ordering {
public static void main( String[ ] args ) {
EntityManagerFactory emfactory = Persistence.createEntityManagerFactory( "Eclipselink_JPA" );
EntityManager entitymanager = emfactory.createEntityManager();
//Between
Query query = entitymanager.createQuery( "Select e " + "from Employee e " + "ORDER BY e.ename ASC" );
List<Employee> list = (List<Employee>)query.getResultList( );
for( Employee e:list ) {
System.out.print("Employee ID :" + e.getEid( ));
System.out.println("\t Employee Name :" + e.getEname( ));
}
}
}
उपरोक्त कार्यक्रम के संकलन और निष्पादन के बाद आपको ग्रहण आईडीई के कंसोल पैनल में आउटपुट निम्नानुसार मिलेगा:
Employee ID :1201 Employee Name :Gopal
Employee ID :1206 Employee Name :Kiran
Employee ID :1205 Employee Name :Krishna
Employee ID :1202 Employee Name :Manisha
Employee ID :1203 Employee Name :Masthanvali
Employee ID :1204 Employee Name :Satish
नाम दिया गया प्रश्न
एक @NamedQuery एनोटेशन को पूर्वनिर्धारित अपरिवर्तनीय क्वेरी स्ट्रिंग के साथ एक क्वेरी के रूप में परिभाषित किया गया है। डायनामिक प्रश्नों के बजाय, नामित प्रश्नों का उपयोग JPJ क्वेरी स्ट्रिंग को POJO से अलग करके कोड संगठन में सुधार कर सकता है। यह क्वेरी स्ट्रिंग में गतिशील रूप से शाब्दिक रूप से एम्बेड करने के बजाय क्वेरी मापदंडों को भी पास करता है और अधिक कुशल प्रश्नों का परिणाम देता है।
सबसे पहले, कर्मचारी इकाई वर्ग के नाम पर @NamedQuery एनोटेशन जोड़ें Employee.java के अंतर्गत com.tutorialspoint.eclipselink.entity पैकेज निम्नानुसार है:
package com.tutorialspoint.eclipselink.entity;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.NamedQuery;
import javax.persistence.Table;
@Entity
@Table
@NamedQuery(query = "Select e from Employee e where e.eid = :id", name = "find employee by id")
public class Employee {
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
private int eid;
private String ename;
private double salary;
private String deg;
public Employee(int eid, String ename, double salary, String deg) {
super( );
this.eid = eid;
this.ename = ename;
this.salary = salary;
this.deg = deg;
}
public Employee( ) {
super();
}
public int getEid( ) {
return eid;
}
public void setEid(int eid) {
this.eid = eid;
}
public String getEname( ) {
return ename;
}
public void setEname(String ename) {
this.ename = ename;
}
public double getSalary( ) {
return salary;
}
public void setSalary(double salary) {
this.salary = salary;
}
public String getDeg( ) {
return deg;
}
public void setDeg(String deg) {
this.deg = deg;
}
@Override
public String toString() {
return "Employee [eid=" + eid + ", ename=" + ename + ", salary=" + salary + ", deg=" + deg + "]";
}
}
नाम से एक क्लास बनाएं NamedQueries.java के अंतर्गत com.tutorialspoint.eclipselink.service पैकेज निम्नानुसार है:
package com.tutorialspoint.eclipselink.service;
import java.util.List;
import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.Persistence;
import javax.persistence.Query;
import com.tutorialspoint.eclipselink.entity.Employee;
public class NamedQueries {
public static void main( String[ ] args ) {
EntityManagerFactory emfactory = Persistence.createEntityManagerFactory( "Eclipselink_JPA" );
EntityManager entitymanager = emfactory.createEntityManager();
Query query = entitymanager.createNamedQuery("find employee by id");
query.setParameter("id", 1204);
List<Employee> list = query.getResultList( );
for( Employee e:list ){
System.out.print("Employee ID :" + e.getEid( ));
System.out.println("\t Employee Name :" + e.getEname( ));
}
}
}
उपरोक्त कार्यक्रम के संकलन और निष्पादन के बाद आपको ग्रहण आईडीई के कंसोल पैनल में आउटपुट निम्नानुसार मिलेगा:
Employee ID :1204 Employee Name :Satish
उपरोक्त सभी वर्गों को जोड़ने के बाद पैकेज पदानुक्रम निम्नानुसार दिखाया गया है:
उत्सुक और आलसी लोड हो रहा है
जेपीए की मुख्य अवधारणा कैश मेमोरी में डेटाबेस की डुप्लिकेट कॉपी बनाना है। डेटाबेस के साथ लेनदेन करते समय, पहले यह डुप्लिकेट डेटा पर प्रभाव डालेगा और केवल तब जब यह इकाई प्रबंधक का उपयोग करने के लिए प्रतिबद्ध होगा, परिवर्तन डेटाबेस में प्रभावित होते हैं।
डेटाबेस से रिकॉर्ड प्राप्त करने के दो तरीके हैं - उत्सुक भ्रूण और आलसी भ्रूण।
उत्सुकता लाने वाला
प्राथमिक कुंजी का उपयोग करते हुए रिकॉर्ड खोजने के दौरान पूरे रिकॉर्ड को प्राप्त करना।
आलसी भ्रूण
यदि यह मौजूद है तो यह प्राथमिक कुंजी के साथ इसे सूचित करने की उपलब्धता की जांच करता है। फिर बाद में यदि आप उस इकाई के किसी भी गेटर विधि को कॉल करते हैं तो यह पूरी प्राप्त करता है।
लेकिन जब आप पहली बार रिकॉर्ड लाने की कोशिश करेंगे तो आलसी भ्रूण संभव है। इस तरह, पूरे रिकॉर्ड की एक प्रतिलिपि पहले से ही कैश मेमोरी में संग्रहीत है। प्रदर्शन के लिहाज से, आलसी भ्रूण बेहतर है।