जेपीए - मानदंड एपीआई

मानदंड एपीआई एक पूर्वनिर्धारित एपीआई है जिसका उपयोग संस्थाओं के लिए प्रश्नों को परिभाषित करने के लिए किया जाता है। यह JPQL क्वेरी को परिभाषित करने का वैकल्पिक तरीका है। ये क्वेरीज़ टाइप-सेफ हैं, और सिंटैक्स को बदलकर पोर्टेबल और आसान बनाना है। JPQL के समान यह अमूर्त स्कीमा (स्कीमा को संपादित करने के लिए आसान) और एम्बेडेड ऑब्जेक्ट्स का अनुसरण करता है। मेटाडेटा एपीआई मापदंड प्रश्नों के लिए लगातार इकाई मॉडल करने के लिए मापदंड एपीआई के साथ mingled है।

मानदंड एपीआई का प्रमुख लाभ यह है कि त्रुटियों को पहले संकलन समय के दौरान पता लगाया जा सकता है। स्ट्रिंग आधारित JPQL प्रश्न और JPA मानदंड आधारित प्रश्न प्रदर्शन और दक्षता में समान हैं।

मापदंड एपीआई का इतिहास

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

  • JPA 2.0 में, मापदंड क्वेरी API, प्रश्नों का मानकीकरण विकसित किया गया है।
  • जेपीए 2.1 में, मानदंड अद्यतन और हटाना (बल्क अपडेट और डिलीट) शामिल हैं।

मानदंड क्वेरी संरचना

मानदंड एपीआई और जेपीक्यूएल निकट से संबंधित हैं और उनके प्रश्नों में समान ऑपरेटरों का उपयोग करके डिजाइन करने की अनुमति है। यह क्वेरी बनाने के लिए javax.persistence.criteria पैकेज का अनुसरण करता है। क्वेरी संरचना का अर्थ है सिंटैक्स मानदंड क्वेरी।

निम्न साधारण मापदंड क्वेरी डेटा स्रोत में इकाई वर्ग के सभी उदाहरणों को लौटाता है।

EntityManager em = ...;
CriteriaBuilder cb = em.getCriteriaBuilder();

CriteriaQuery<Entity class> cq = cb.createQuery(Entity.class);
Root<Entity> from = cq.from(Entity.class);

cq.select(Entity);
TypedQuery<Entity> q = em.createQuery(cq);
List<Entity> allitems = q.getResultList();

मानदंड बनाने के लिए क्वेरी मूल चरणों का प्रदर्शन करती है।

  • EntityManager उदाहरण का उपयोग क्राइटेरियाब्यूस्ट ऑब्जेक्ट बनाने के लिए किया जाता है ।
  • क्वेरी ऑब्जेक्ट बनाने के लिए CriteriaQuery उदाहरण का उपयोग किया जाता है। इस क्वेरी ऑब्जेक्ट की विशेषताओं को क्वेरी के विवरण के साथ संशोधित किया जाएगा।
  • क्वेरी रूट सेट करने के लिए CriteriaQuery.from विधि को कहा जाता है।
  • परिणाम सूची प्रकार सेट करने के लिए CriteriaQuery.select को कहा जाता है।
  • टंकण के प्रकार को निर्दिष्ट करने और निष्पादन के लिए एक क्वेरी तैयार करने के लिए टाइप किए जाने वाले <T> उदाहरण का उपयोग किया जाता है।
  • किसी क्वेरी को निष्पादित करने के लिए टाइप करेंडाइक <T> ऑब्जेक्ट पर ResResList पद्धति । यह क्वेरी संस्थाओं का एक संग्रह लौटाती है, परिणाम एक सूची में संग्रहीत होता है।

मापदंड एपीआई का उदाहरण

आइए हम कर्मचारी डेटाबेस के उदाहरण पर विचार करें। हमें मान लें कि jpadb.employee तालिका में निम्नलिखित रिकॉर्ड हैं:

Eid	Ename           Salary	Deg
401	Gopal	        40000	Technical Manager
402	Manisha	        40000	Proof reader
403	Masthanvali     35000	Technical Writer
404     Satish	        30000	Technical writer
405	Krishna	        30000	Technical Writer
406	Kiran	        35000	Proof reader

नामांकित ग्रहण IDE में एक JPA प्रोजेक्ट बनाएं JPA_Eclipselink_Criteria। इस परियोजना के सभी मॉड्यूल निम्नानुसार दिखाए गए हैं:

संस्थाओं का निर्माण

नाम का पैकेज बनाएं com.tutorialspoint.eclipselink.entity के अंतर्गत ‘src’ पैकेज।

नाम की एक क्लास बनाएं Employee.javaदिए गए पैकेज के तहत। कर्मचारी वर्ग को निम्नानुसार दिखाया गया है:

package com.tutorialspoint.eclipselink.entity;

import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;

@Entity
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 + "]";
   }
}

Persistence.xml

Persistence.xml फ़ाइल को डेटाबेस और इकाई वर्गों के पंजीकरण को कॉन्फ़िगर करने के लिए आवश्यक है।

Persistence.xml एक EPA प्रोजेक्ट के दौरान ग्रहण आईडीई द्वारा बनाया जाएगा। कॉन्फ़िगरेशन विवरण उपयोगकर्ता के विनिर्देश हैं। दृढ़ता। Xml फ़ाइल निम्नानुसार दिखाई गई है:

<?xml version = "1.0" encoding = "UTF-8"?>
<persistence version="2.0" xmlns = "http://java.sun.com/xml/ns/persistence" 
   xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance" 
   xsi:schemaLocation = "http://java.sun.com/xml/ns/persistence 
   http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd">
   
   <persistence-unit name = "Eclipselink_JPA" transaction-type = "RESOURCE_LOCAL">
      <class>com.tutorialspoint.eclipselink.entity.Employee</class>
      
      <properties>
         <property name = "javax.persistence.jdbc.url" value = "jdbc:mysql://localhost:3306/jpadb"/>
         <property name = "javax.persistence.jdbc.user" value = "root"/>
         <property name = "javax.persistence.jdbc.password" value = "root"/>
         <property name = "javax.persistence.jdbc.driver" 
         value="com.mysql.jdbc.Driver"/>
         <property name = "eclipselink.logging.level" value = "FINE"/>
         <property name = "eclipselink.ddl-generation" 
         value="create-tables"/>
      </properties>
      
   </persistence-unit>
</persistence>

सेवा वर्ग

इस मॉड्यूल में सेवा वर्ग शामिल हैं, जो मेटाडेटा एपीआई आरंभीकरण का उपयोग करते हुए मानदंड क्वेरी भाग को लागू करता है। नाम का पैकेज बनाएं‘com.tutorialspoint.eclipselink.service’। नाम का वर्गCriteriaAPI.javaदिए गए पैकेज के तहत बनाया गया है। DAO वर्ग निम्नानुसार दिखाया गया है:

package com.tutorialspoint.eclipselink.service;

import java.util.List;

import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.Persistence;
import javax.persistence.TypedQuery;
import javax.persistence.criteria.CriteriaBuilder;
import javax.persistence.criteria.CriteriaQuery;
import javax.persistence.criteria.Root;

import com.tutorialspoint.eclipselink.entity.Employee;

public class CriteriaApi {
   public static void main(String[] args) {
   
   EntityManagerFactory emfactory = Persistence.createEntityManagerFactory( "Eclipselink_JPA" );
   EntityManager entitymanager = emfactory.createEntityManager( );
   CriteriaBuilder criteriaBuilder = entitymanager.getCriteriaBuilder();
   CriteriaQuery<Object> criteriaQuery = criteriaBuilder.createQuery();
   Root<Employee> from = criteriaQuery.from(Employee.class);

   //select all records
   System.out.println(“Select all records”);
   CriteriaQuery<Object> select = c riteriaQuery.select(from);
   TypedQuery<Object> typedQuery = entitymanager.createQuery(select);
   List<Object> resultlist = typedQuery.getResultList();

   for(Object o:resultlist) {
      Employee e = (Employee)o;
      System.out.println("EID : " + e.getEid() + " Ename : " + e.getEname());
   }

   //Ordering the records 
   System.out.println(“Select all records by follow ordering”);
   CriteriaQuery<Object> select1 = criteriaQuery.select(from);
   select1.orderBy(criteriaBuilder.asc(from.get("ename")));
   TypedQuery<Object> typedQuery1 = entitymanager.createQuery(select);
   List<Object> resultlist1 = typedQuery1.getResultList();

   for(Object o:resultlist1){
      Employee e=(Employee)o;
      System.out.println("EID : " + e.getEid() + " Ename : " + e.getEname());
   }

   entitymanager.close( );
   emfactory.close( );
   }
}

उपरोक्त कार्यक्रम के संकलन और निष्पादन के बाद आपको ग्रहण आईडीई के कंसोल पैनल में आउटपुट निम्नानुसार मिलेगा:

Select All records
EID : 401 Ename : Gopal
EID : 402 Ename : Manisha
EID : 403 Ename : Masthanvali
EID : 404 Ename : Satish
EID : 405 Ename : Krishna
EID : 406 Ename : Kiran
Select All records by follow Ordering
EID : 401 Ename : Gopal
EID : 406 Ename : Kiran
EID : 405 Ename : Krishna
EID : 402 Ename : Manisha
EID : 403 Ename : Masthanvali
EID : 404 Ename : Satish