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 चयनित नोड का प्रतिनिधित्व करता है, "/" का उपयोग आवश्यक तत्व, मूल्य, शीर्षक का मूल्य प्राप्त करने के लिए किया जाता है; "वापसी" खंड का उपयोग खोज परिणामों से तत्वों को वापस करने के लिए किया जाता है।