XQuery - पहला आवेदन

उदाहरण

निम्नलिखित एक नमूना XML दस्तावेज़ है जिसमें विभिन्न पुस्तकों के बुकस्टोर के रिकॉर्ड हैं।

books.xml

<?xml version="1.0" encoding="UTF-8"?>
<books>
   
   <book category="JAVA">
      <title lang="en">Learn Java in 24 Hours</title>
      <author>Robert</author>
      <year>2005</year>
      <price>30.00</price>
   </book>
   
   <book category="DOTNET">
      <title lang="en">Learn .Net in 24 hours</title>
      <author>Peter</author>
      <year>2011</year>
      <price>70.50</price>
   </book>
   
   <book category="XML">
      <title lang="en">Learn XQuery in 24 hours</title>
      <author>Robert</author>
      <author>Peter</author> 
      <year>2013</year>
      <price>50.00</price>
   </book>
   
   <book category="XML">
      <title lang="en">Learn XPath in 24 hours</title>
      <author>Jay Ban</author>
      <year>2010</year>
      <price>16.50</price>
   </book>
   
</books>

निम्नलिखित एक्सएमएल दस्तावेज़ पर निष्पादित करने के लिए क्वेरी एक्सप्रेशन वाला एक नमूना Xquery दस्तावेज़ है। उद्देश्य उन XML नोड्स के शीर्षक तत्वों को प्राप्त करना है जहां कीमत 30 से अधिक है।

books.xqy

for $x in doc("books.xml")/books/book where $x/price>30
return $x/title

परिणाम

<title lang="en">Learn .Net in 24 hours</title>
<title lang="en">Learn XQuery in 24 hours</title>

परिणाम सत्यापित करें

परिणाम को सत्यापित करने के लिए, उपरोक्त XQuery अभिव्यक्ति के साथ books.xqy ( पर्यावरण सेटअप अध्याय में दी गई ) की सामग्री को बदलें और XQueryTester जावा प्रोग्राम को निष्पादित करें।

XQuery अभिव्यक्तियाँ

आइए हम उपरोक्त XQuery अभिव्यक्ति के प्रत्येक टुकड़े को समझें।

कार्यों का उपयोग

doc("books.xml")

doc () XQuery फ़ंक्शंस में से एक है जो XML स्रोत का पता लगाने के लिए उपयोग किया जाता है। यहाँ हमने "books.xml" पास किया है। सापेक्ष पथ को ध्यान में रखते हुए, books.xml उसी पथ में झूठ बोलना चाहिए जहाँ books.xqy मौजूद है।

XPath अभिव्यक्तियों का उपयोग

doc("books.xml")/books/book

एक्सआईएमएक्स एक्सएमएल एक्सप्रेशंस का उपयोग करता है जो एक्सएमएल के आवश्यक हिस्से का पता लगाने के लिए जिस पर खोज की जानी है। यहां हमने पुस्तकों के नोड के तहत उपलब्ध सभी पुस्तक नोड्स को चुना है।

वस्तुओं में फेरबदल करें

for $x in doc("books.xml")/books/book

XQuery वस्तुओं के रूप में xml डेटा का व्यवहार करता है। उपरोक्त उदाहरण में, $ x चयनित नोड का प्रतिनिधित्व करता है, जबकि लूप के लिए नोड्स के संग्रह पर पुनरावृत्त होता है।

शर्त लागू करें

where $x/price>30

चूंकि $ x चयनित नोड का प्रतिनिधित्व करता है, "/" का उपयोग आवश्यक तत्व के मूल्य को प्राप्त करने के लिए किया जाता है; "जहां" खंड का उपयोग खोज परिणामों पर एक शर्त लगाने के लिए किया जाता है।

परिणाम लौटाओ

return $x/title

चूंकि $ x चयनित नोड का प्रतिनिधित्व करता है, "/" का उपयोग आवश्यक तत्व, मूल्य, शीर्षक का मूल्य प्राप्त करने के लिए किया जाता है; "वापसी" खंड का उपयोग खोज परिणामों से तत्वों को वापस करने के लिए किया जाता है।