CodeGym /படிப்புகள் /SQL & Hibernate /அளவுகோல் API

அளவுகோல் API

SQL & Hibernate
நிலை 16 , பாடம் 0
கிடைக்கப்பெறுகிறது

Criteria API அறிமுகம்

ஹைபர்னேட்டில் தரவுத்தள வினவல்களை எழுத இரண்டு வழிகள் உள்ளன:

  • ஹைபர்னேட் வினவல் மொழி
  • அளவுகோல் API

நீங்கள் ஏற்கனவே நீண்ட காலத்திற்கு முன்பு முதல்வரைச் சந்தித்திருக்கிறீர்கள், இது Criteria API உடன் பழகுவதற்கான நேரம். இது மிகவும் சக்திவாய்ந்த கருவியாகும், சில சமயங்களில் இது HQL ஐ விட மிகவும் பிரபலமானது. இப்போது இது மிகவும் பிரபலமாக இல்லை, ஆனால் சில பணிகளுக்கு இது நிச்சயமாக HQL ஐ விட சிறந்த தீர்வாக இருக்கும்.

எவ்வாறாயினும், Criteria API ஐப் பற்றி நன்கு தெரிந்து கொள்ளாமல், நீங்கள் ஹைபர்னேட்டைக் கற்றுக்கொள்ள முடியாது. ஒரு சிறிய உதாரணத்தை எழுதுவோம், பின்னர் அதை பகுப்பாய்வு செய்வோம். எடுத்துக்காட்டாக, தரவுத்தளத்திலிருந்து அனைத்து ஊழியர்களையும் (பணியாளர்) கோருவோம். நாம் பெறுவது இங்கே:

CriteriaBuilder builder = session.getCriteriaBuilder();
CriteriaQuery<Employee> critQuery = builder.createQuery(Employee.class);

Root<Employee> root = critQuery.from(Employee.class);
critQuery.select(root);

Query<Employee> query = session.createQuery(critQuery);
List<Employee> results = query.getResultList();

சிக்கலானதாகத் தெரிகிறது. ஒப்பிடுவதற்கு அதே HQL வினவலை எழுதுவோம்:

String hqlQuery = "from Employee";

Query<Employee> query = session.createQuery(hqlQuery);
List<Employee> results = query.getResultList();

இரண்டு எடுத்துக்காட்டுகளின் கடைசி இரண்டு வரிகளும் ஏறக்குறைய ஒரே மாதிரியானவை என்பதை நினைவில் கொள்ளவும்: வினவல் பொருளை உருவாக்கி, பட்டியலைப் பெற அதைப் பயன்படுத்துகிறோம். மீதமுள்ள வரிகள் ஒரே மாதிரியான ஒன்றைச் செய்கின்றன என்பதை இது குறிக்கிறது.

முதல் உதாரணத்தின் 3 மற்றும் 4 வரிகளைப் பாருங்கள்:

Root<Employee> root = critQuery.from(Employee.class);
critQuery.select(root);

அவற்றை ஒரே வரியில் எழுதுவோம்:

critQuery.select(critQuery.from(Employee.class));

இது உங்களுக்கு எதையும் நினைவூட்டவில்லையா? நீங்கள் அதை சற்று வித்தியாசமாக வண்ணமயமாக்கினால்:

critQuery.select(critQuery.from(Employee.class));

ஆம், இது SELECT FROM வினவலின் மிகவும் தந்திரமான கட்டுமானமாகும்.

Criteria API உடன் பணிபுரிவதற்கான எடுத்துக்காட்டுகள்

சிறந்த புரிதலுக்காக, நான் சில எடுத்துக்காட்டுகளைத் தருகிறேன்.

கோரிக்கை 1 . 10 ஆயிரத்துக்கு மேல் சம்பளம் உள்ள அனைத்து ஊழியர்களையும் பெறுங்கள்:

critQuery.select(critQuery.from(Employee.class)).where(builder.gt(root.get("salary"), 10000));

கோரிக்கை 2 . 50 ஆயிரத்துக்கும் குறைவான சம்பளம் உள்ள அனைத்து ஊழியர்களையும் பெறுங்கள்:

critQuery.select(critQuery.from(Employee.class)).where(builder.lt(root.get("salary"), 50000));

கோரிக்கை 3 . பணித் தலைப்பில் "சோதனை" என்ற வார்த்தை உள்ள அனைத்து ஊழியர்களையும் பெறவும்:

critQuery.select(critQuery.from(Employee.class)).where(builder.like(root.get("occupation"), "%test%"));

கோரிக்கை 4 . 10 முதல் 50 ஆயிரம் வரை சம்பளம் உள்ள அனைத்து ஊழியர்களையும் பெறுங்கள்:

critQuery.select(critQuery.from(Employee.class)).where(builder.between(root.get("salary"), 10000, 50000));

கோரிக்கை 5 . பெயர் பூஜ்யமாக உள்ள அனைத்து ஊழியர்களையும் பெறவும்:

critQuery.select(critQuery.from(Employee.class)).where(builder.isNull(root.get("name")));

கோரிக்கை 6 . பெயர் பூஜ்யமாக இல்லாத அனைத்து ஊழியர்களையும் பெறவும்:

critQuery.select(critQuery.from(Employee.class)).where(builder.isNotNull(root.get("name")));

வினவலை உருவாக்க இது ஒரு தந்திரமான வழி:

  • முதலில் நீங்கள் பொருளைப் பெறுவீர்கள்அளவுகோல் கட்டுபவர்.
  • பின்னர் ஒரு பொருளை உருவாக்க அதைப் பயன்படுத்தவும்அளவுகோல் வினவல்.
  • அதன் பிறகு, அதன் பாகங்களைச் சேர்க்கத் தொடங்குங்கள்அளவுகோல் வினவல்மற்றும்அளவுகோல் கட்டுபவர்.

இப்படி நீங்கள் அளவுருக்களை அமைக்கலாம்:

  • தேர்ந்தெடுக்கவும்
  • இருந்து
  • எங்கே

பயன்படுத்தவும்அளவுகோல் கட்டுபவர்நீங்கள் எங்கு வெவ்வேறு நிலைமைகளை உருவாக்க முடியும்.

Criteria API உடன் மேம்பட்ட வேலை

Criteria API ஐப் பயன்படுத்தி, எந்தவொரு சிக்கலான கேள்வியையும் நீங்கள் உருவாக்கலாம். மேலும் இது ஒரு சிறந்த செய்தி. எடுத்துக்காட்டாக, உங்களுக்கு ஒரு சிக்கலான WHERE விதி தேவை. அதை எப்படி செய்வது என்பது இங்கே:

Predicate greaterThan = builder.gt(root.get("salary"), 1000);
Predicate testers = builder.like(root.get("occupation"), "test%");

critQuery.select(critQuery.from(Employee.class)).where(builder.or(greaterThan, testers));

OR க்கு பதிலாக AND என்று எழுத விரும்பினால், கடைசி வரியை மட்டும் மாற்ற வேண்டும்:

critQuery.select(critQuery.from(Employee.class)).where(builder.and(greaterThan, testers));

எல்லாம் உண்மையில் மிகவும் எளிமையானது. சில ஒப்பீடுகளுடன் ஒரு அட்டவணையைத் தருகிறேன்:

SQL முறை முழு பதிவு
a<b lt(a, b) builder.lt(a, b)
a > b gt(a, b) builder.gt(a, b)
a OR b அல்லது(a,b) builder.or(a, b)
a மற்றும் b மற்றும்(a,b) builder.and(a,b)
ஒரு லைக் ஆ போன்ற(a, b) கட்டடம்.like(a, b)
ஒரு இடையே (c, d) இடையே (a, c, d) பில்டர்.இடையில்(a, c, d)
a பூஜ்யமானது isNull(a) builder.isNull(a)
a பூஜ்யமாக இல்லை isNotNull(a) builder.isNotNull(a)

எல்லாம் எளிது, இல்லையா?

மேலும் வினவலில் வரிசையாக்கத்தை எவ்வாறு சேர்ப்பது? மிக எளிய:

critQuery.select( critQuery.from(Employee.class) );
critQuery.where( builder.and(greaterThan, testers) );
critQuery.orderBy( builder.asc(root.get("salary"), builder.desc(root.get("joinDate") )

நீங்கள் பொருளை மட்டும் அழைக்கிறீர்கள்அளவுகோல் வினவல்orderBy() முறை மற்றும் தேவையான அளவுருக்களை அதற்கு அனுப்பவும்.

HQL இல் அதே வினவல் எப்படி இருக்கும் என்பது இங்கே. ஒப்பிடு:

select * from Employee
where (…) and (…)
order by 'salary' asc, 'joinDate' desc

நீங்கள் 3 விஷயங்களை நினைவில் கொள்ள வேண்டும்:

  • SELECT, FROM, WHERE போன்ற முக்கிய ஆபரேட்டர்கள் ஒரு பொருளில் அழைக்கப்படுகின்றனஅளவுகோல் வினவல்.
  • AND, OR, DESC போன்ற துணை ஆபரேட்டர்கள் பொருளில் அழைக்கப்படுகின்றனர்அளவுகோல் கட்டுபவர்.
  • புலத்தின் பெயர்கள் பொருளிலிருந்து get() வழியாக எடுக்கப்படுகின்றன.வேர்.
கருத்துக்கள்
TO VIEW ALL COMMENTS OR TO MAKE A COMMENT,
GO TO FULL VERSION