NHibernate - हाइबरनेट क्वेरी भाषा

इस अध्याय में, हम हाइबरनेट क्वेरी भाषा को कवर करेंगे। HQL को जावा के हाइबरनेट और NHibernate दोनों में साझा किया गया है।

  • यह सबसे पुराना क्वेरी तंत्र है Criteria

  • इसे बहुत पहले लागू किया गया था और यह एक स्ट्रिंग-आधारित क्वेरी है API

  • आप इसके माध्यम से पहुँचते हैं ISession CreateQuery, और यह लगभग SQL के समान है।

  • यह एक ही कीवर्ड के कई का उपयोग करता है, लेकिन एक सरलीकृत वाक्यविन्यास है।

  • यह सबसे आम उदाहरणों में से एक है, यदि आप खोज करना चाहते हैं कि एक क्वेरी कैसे करें तो आप अक्सर HQL उदाहरण पाएंगे।

निम्नलिखित HQL का एक सरल उदाहरण है -

var customers = session.CreateQuery("select c from Customer c where c.FirstName = 'Laverne'");
  • तो यहां आप देख सकते हैं कि वे ग्राहक से सी का चयन करते हैं, यह एसक्यूएल जैसा दिखता है। यह एक अपारदर्शी स्ट्रिंग है जहाँ तक NHibernate का संबंध है, इसलिए आप नहीं जानते कि क्या यह रनवे तक एक वैध HQL है, जो नुकसान में से एक है।

  • LINQ प्रदाता की ताकत में से एक आप समय समर्थन संकलन करने के लिए प्राप्त कर सकते हैं।

  • लेकिन HQL, अक्सर उपयोग किए जाने वाले सबसे लचीले क्वेरी तंत्रों में से एक है। ऐसा कहा जाता है कि, अगर ऐसा करने का कोई दूसरा तरीका नहीं है, तो HQL में इसे करने का एक तरीका है।

आइए एक उपमा उदाहरण देखें जिसमें हम HQL का उपयोग करके हमारे LINQ प्रश्नों को फिर से बनाएंगे। आप कॉल करके HQL तक पहुँच प्राप्त कर सकते हैंsession.CreateQuery और HQL स्ट्रिंग का उपयोग करके एक पैरामीटर के रूप में पास करें।

using System; 
using System.Data; 
using System.Linq; 
using System.Reflection; 

using HibernatingRhinos.Profiler.Appender.NHibernate; 
using NHibernate.Cfg; 
using NHibernate.Criterion; 
using NHibernate.Dialect; 
using NHibernate.Driver; 
using NHibernate.Linq;

namespace NHibernateDemo {

   internal class Program { 
      
      private static void Main() { 
		
         var cfg = ConfigureNHibernate(); 
         var sessionFactory = cfg.BuildSessionFactory();
         using(var session = sessionFactory.OpenSession()) 
         
         using(var tx = session.BeginTransaction()) { 
            var customers = session.CreateQuery("select c from Customer c 
               where c.FirstName = 'Laverne'"); 
            
            foreach (var customer in customers.List<Customer>()) { 
               Console.WriteLine(customer); 
            }
				
            tx.Commit(); 
         }
			
         Console.WriteLine("Press <ENTER> to exit..."); 
         Console.ReadLine(); 
      }
		
      private static Configuration ConfigureNHibernate() { 
		
         NHibernateProfiler.Initialize(); 
         var cfg = new Configuration(); 
         
         cfg.DataBaseIntegration(x => { 
            x.ConnectionStringName = "default"; 
            x.Driver<SqlClientDriver>(); 
            x.Dialect<MsSql2008Dialect>(); 
            x.IsolationLevel = IsolationLevel.RepeatableRead; 
            x.Timeout = 10; 
            x.BatchSize = 10; 
         }); 
         
         cfg.SessionFactory().GenerateStatistics();
         cfg.AddAssembly(Assembly.GetExecutingAssembly()); 
         return cfg; 
      } 
   } 
}
  • यह एचक्यूएल स्ट्रिंग एसक्यूएल की तरह दिखता है, मुख्य अंतर यह है कि फर्स्टनाम संपत्ति का नाम है न कि कॉलम नाम।

  • इसलिए, अगर दोनों के बीच कोई विसंगति है, तो आप संपत्ति के नाम का उपयोग करते हैं। एक ही बात, यह एक तालिका नाम की तरह दिखता है, लेकिन यह वास्तव में उस वर्ग का नाम है जिसे हम चुन रहे हैं।

  • यदि बैक एंड टेबल को ग्राहक के रूप में नामित किया गया था, तो हम अभी भी अपनी एचक्यूएल क्वेरी में ग्राहक का उपयोग करेंगे।

आइए इस एप्लिकेशन को चलाएं और आपको निम्न आउटपुट दिखाई देगा।

Laverne Hegmann (4e97c816-6bce-11e1-b095-6cf049ee52be)
   Points: 74
   HasGoldStatus: True
   MemberSince: 4/4/2009 12:00:00 AM (Utc)
   CreditRating: Neutral
   AverageRating: 0

   Orders:
      Order Id: 4ea14d96-6bce-11e1-b095-6cf049ee52be
      Order Id: 4ea14d96-6bce-11e1-b096-6cf049ee52be
      Order Id: 4ea14d96-6bce-11e1-b097-6cf049ee52be
      Order Id: 4ea14d96-6bce-11e1-b098-6cf049ee52be
		
Press <ENTER> to exit...

आइए एक और सरल उदाहरण देखें जिसमें हम उन सभी ग्राहकों को पुनः प्राप्त करेंगे जिनका फर्स्टनाम HQL का उपयोग करते हुए H अक्षर से शुरू होता है।

using System; 
using System.Data; 
using System.Linq; 
using System.Reflection; 

using HibernatingRhinos.Profiler.Appender.NHibernate; 
using NHibernate.Cfg; 
using NHibernate.Criterion; 
using NHibernate.Dialect; 
using NHibernate.Driver;
using NHibernate.Linq; 

namespace NHibernateDemo { 

   internal class Program {
	
      private static void Main() { 
		
         var cfg = ConfigureNHibernate(); 
         var sessionFactory = cfg.BuildSessionFactory();
         using(var session = sessionFactory.OpenSession()) 
         
         using(var tx = session.BeginTransaction()) { 
            var customers = session.CreateQuery("select c from Customer c 
               where c.FirstName like 'H%'"); 
            
            foreach (var customer in customers.List<Customer>()) { 
               Console.WriteLine(customer); 
            }
				
            tx.Commit(); 
         } 
			
         Console.WriteLine("Press <ENTER> to exit..."); 
         Console.ReadLine(); 
      } 
		
      private static Configuration ConfigureNHibernate() {
		
         NHibernateProfiler.Initialize(); 
         var cfg = new Configuration(); 
         
         cfg.DataBaseIntegration(x => { 
            x.ConnectionStringName = "default"; 
            x.Driver<SqlClientDriver>(); 
            x.Dialect<MsSql2008Dialect>(); 
            x.IsolationLevel = IsolationLevel.RepeatableRead; 
            x.Timeout = 10; 
            x.BatchSize = 10; 
         }); 
			
         cfg.SessionFactory().GenerateStatistics();
         cfg.AddAssembly(Assembly.GetExecutingAssembly()); 
         return cfg; 
      } 
   } 
}

आइए अपना एप्लिकेशन फिर से चलाएं और आप देखेंगे कि जिन ग्राहकों का नाम H से शुरू होता है वे सभी इस क्वेरी से वापस आ जाते हैं।

Herman Crooks (4ead3480-6bce-11e1-b15c-6cf049ee52be)
   Points: 74
   HasGoldStatus: True
   MemberSince: 12/3/2010 12:00:00 AM (Utc)
   CreditRating: Neutral
   AverageRating: 0

   Orders:
      Order Id: 4ead3480-6bce-11e1-b15d-6cf049ee52be
      Order Id: 4ead3480-6bce-11e1-b15e-6cf049ee52be
      Order Id: 4ead3480-6bce-11e1-b15f-6cf049ee52be
      Order Id: 4ead3480-6bce-11e1-b160-6cf049ee52be
      Order Id: 4ead3480-6bce-11e1-b161-6cf049ee52be
      Order Id: 4ead3480-6bce-11e1-b162-6cf049ee52be
      Order Id: 4ead3480-6bce-11e1-b163-6cf049ee52be

Hudson Bins (4ec03f80-6bce-11e1-b2b7-6cf049ee52be)
   Points: 56
   HasGoldStatus: False
   MemberSince: 10/20/2008 12:00:00 AM (Utc)
   CreditRating: Terrible
   AverageRating: 0

   Orders:
      Order Id: 4ec03f80-6bce-11e1-b2b8-6cf049ee52be
      Order Id: 4ec03f80-6bce-11e1-b2b9-6cf049ee52be
      Order Id: 4ec03f80-6bce-11e1-b2ba-6cf049ee52be
      Order Id: 4ec03f80-6bce-11e1-b2bb-6cf049ee52be
      Order Id: 4ec03f80-6bce-11e1-b2bc-6cf049ee52be
      Order Id: 4ec03f80-6bce-11e1-b2bd-6cf049ee52be
      Order Id: 4ec03f80-6bce-11e1-b2be-6cf049ee52be
      Order Id: 4ec03f80-6bce-11e1-b2bf-6cf049ee52be

Hettie Feest (4ec50240-6bce-11e1-b300-6cf049ee52be)
   Points: 82
   HasGoldStatus: False
   MemberSince: 4/10/2009 12:00:00 AM (Utc)
   CreditRating: Neutral
   AverageRating: 0

   Orders:
      Order Id: 4ec50240-6bce-11e1-b301-6cf049ee52be
      Order Id: 4ec50240-6bce-11e1-b302-6cf049ee52be
      Order Id: 4ec50240-6bce-11e1-b303-6cf049ee52be
		
Press <ENTER> to exit...

हम सभी ऑर्डर चाहने जैसी अधिक जटिल चीजें कर सकते हैं जहां ऑर्डर काउंट वाले ग्राहक 9. से अधिक हैं। उसी के लिए HQL क्वेरी है।

var customers = session.CreateQuery("select c from Customer c 
   where size(c.Orders) > 9"); 
	
foreach (var customer in customers.List<Customer>()) { 
   Console.WriteLine(customer); 
}

हमें यह भी इंगित करने की आवश्यकता है कि हमें यहां एक आकार या गिनती या लंबाई की आवश्यकता है। HQL में, हमारे पास विशेष आकार विधि का उपयोग करने का विकल्प है जैसा कि ऊपर दिखाया गया है।

यदि आप पसंद करते हैं, तो इसे लिखने का दूसरा तरीका है c.Orders.size, और इसका सटीक प्रभाव है।

var customers = session.CreateQuery("select c from Customer c 
   where c.Orders.size > 9"); 
	
foreach (var customer in customers.List<Customer>()) { 
   Console.WriteLine(customer); 
}

आइए इस एप्लिकेशन को चलाते हैं।

Lindsay Towne (4ea3aef6-6bce-11e1-b0cb-6cf049ee52be)
   Points: 50
   HasGoldStatus: False
   MemberSince: 4/13/2007 12:00:00 AM (Utc)
   CreditRating: VeryGood
   AverageRating: 0

   Orders:
      Order Id: 4ea3aef6-6bce-11e1-b0cc-6cf049ee52be
      Order Id: 4ea3aef6-6bce-11e1-b0cd-6cf049ee52be
      Order Id: 4ea3aef6-6bce-11e1-b0ce-6cf049ee52be
      Order Id: 4ea3aef6-6bce-11e1-b0cf-6cf049ee52be
      Order Id: 4ea3aef6-6bce-11e1-b0d0-6cf049ee52be
      Order Id: 4ea3aef6-6bce-11e1-b0d1-6cf049ee52be
      Order Id: 4ea3aef6-6bce-11e1-b0d2-6cf049ee52be
      Order Id: 4ea3aef6-6bce-11e1-b0d3-6cf049ee52be
      Order Id: 4ea3aef6-6bce-11e1-b0d4-6cf049ee52be
      Order Id: 4ea3aef6-6bce-11e1-b0d5-6cf049ee52be

Wyman Hammes (4ea61056-6bce-11e1-b0e2-6cf049ee52be)
   Points: 32
   HasGoldStatus: False
   MemberSince: 2/5/2011 12:00:00 AM (Utc)
   CreditRating: Good
   AverageRating: 0

   Orders:
      Order Id: 4ea61056-6bce-11e1-b0e3-6cf049ee52be
      Order Id: 4ea61056-6bce-11e1-b0e4-6cf049ee52be
      Order Id: 4ea61056-6bce-11e1-b0e5-6cf049ee52be
      Order Id: 4ea61056-6bce-11e1-b0e6-6cf049ee52be
      Order Id: 4ea61056-6bce-11e1-b0e7-6cf049ee52be
      Order Id: 4ea61056-6bce-11e1-b0e8-6cf049ee52be
      Order Id: 4ea61056-6bce-11e1-b0e9-6cf049ee52be
      Order Id: 4ea61056-6bce-11e1-b0ea-6cf049ee52be
      Order Id: 4ea61056-6bce-11e1-b0eb-6cf049ee52be
      Order Id: 4ea61056-6bce-11e1-b0ec-6cf049ee52be
		
Press <ENTER> to exit...

आप देख सकते हैं कि सभी ग्राहक, जिनके पास 9 से अधिक ऑर्डर हैं, डेटाबेस से पुनर्प्राप्त किए जाते हैं।