XQuery - त्वरित गाइड

XQuery क्या है

XQuery एक कार्यात्मक भाषा है जिसका उपयोग XML प्रारूप में संग्रहीत जानकारी को पुनः प्राप्त करने के लिए किया जाता है। XQuery का उपयोग XML दस्तावेजों, XML डेटाबेस या डेटा डेटाबेस में डेटा से संबंधित रिलेशनल डेटाबेस पर किया जा सकता है। 8 अप्रैल 2014 से XQuery 3.0 W3C की सिफारिश है।

XQuery की परिभाषा इसके आधिकारिक दस्तावेज द्वारा दी गई है, इस प्रकार है -

XQuery दस्तावेज़, डेटाबेस, वेब पेज और लगभग कुछ भी संयोजन के लिए एक मानकीकृत भाषा है। यह बहुत व्यापक रूप से लागू है। यह शक्तिशाली और सीखने में आसान है। XQuery मालिकाना मिडलवेयर भाषाओं और वेब अनुप्रयोग विकास भाषाओं की जगह ले रहा है। XQuery कोड की कुछ पंक्तियों के साथ जटिल Java या C ++ प्रोग्राम को बदल रहा है। XQuery के साथ काम करना आसान है और कई अन्य विकल्पों की तुलना में बनाए रखना आसान है।

विशेषताएँ

  • Functional Language - XQuery XML आधारित डेटा को पुनः प्राप्त / क्वेरी करने के लिए एक भाषा है।

  • Analogous to SQL - XQuery XML के लिए है जो SQL डेटाबेस के लिए है।

  • XPath based - XQuery XML दस्तावेजों के माध्यम से नेविगेट करने के लिए XPath अभिव्यक्तियों का उपयोग करता है।

  • Universally accepted - XQuery सभी प्रमुख डेटाबेस द्वारा समर्थित है।

  • W3C Standard - XQuery एक W3C मानक है।

XQuery के लाभ

  • XQuery का उपयोग करके, पदानुक्रमित और सारणीबद्ध डेटा दोनों को पुनर्प्राप्त किया जा सकता है।

  • XQuery का उपयोग ट्री और ग्राफिकल संरचनाओं को क्वेरी करने के लिए किया जा सकता है।

  • XQuery का उपयोग सीधे वेबपेजों को क्वेरी करने के लिए किया जा सकता है।

  • XQuery का उपयोग सीधे वेबपेज बनाने के लिए किया जा सकता है।

  • XQuery दस्तावेजों को बदलने के लिए XQuery का उपयोग किया जा सकता है।

  • XQuery XML- आधारित डेटाबेस और ऑब्जेक्ट-आधारित डेटाबेस के लिए आदर्श है। ऑब्जेक्ट डेटाबेस विशुद्ध रूप से सारणीबद्ध डेटाबेस की तुलना में बहुत अधिक लचीले और शक्तिशाली होते हैं।

यह अध्याय स्थानीय विकास के वातावरण में XQuery लाइब्रेरी स्थापित करने के तरीके के बारे में बताता है।

हम एक ओपन सोर्स स्टैंडअलोन XQuery प्रोसेसर सैक्सन होम एडिशन (सैक्सन-एचई) का उपयोग कर रहे हैं जो व्यापक रूप से उपयोग किया जाता है। यह प्रोसेसर XSLT 2.0, XQuery 3.0 और XPath 3.0 का समर्थन करता है और प्रदर्शन के लिए अत्यधिक अनुकूलित है। Saxon XQuery प्रोसेसर का उपयोग बिना किसी XML डेटाबेस के किया जा सकता है। हम अपने उदाहरणों में हमारे डेटाबेस के रूप में एक सरल XML दस्तावेज़ का उपयोग करेंगे।

Saxon XQuery प्रोसेसर का उपयोग करने के लिए, आपके पास अपने आवेदन के क्लासपाथ में saxon9he.jar, saxon9-test.jar, saxon9-unpack, saxon9-xqj.jar होना चाहिए। ये जार फाइलें डाउनलोड फाइल में उपलब्ध हैंSaxonHE9-6-0-1J.zipSaxonHE9-6-0-1J.zip डाउनलोड करें ।

उदाहरण

हम books.xqy का परीक्षण करने के लिए जावा-आधारित सैक्सन XQuery प्रोसेसर का उपयोग करेंगे, हमारे नमूना XML दस्तावेज़ के खिलाफ XQuery अभिव्यक्ति वाली एक फ़ाइल, अर्थात, books.xml।

इस उदाहरण में, हम देखेंगे कि उन पुस्तकों के शीर्षक तत्वों को प्राप्त करने के लिए कैसे लिखना और संसाधित करना है जिनकी कीमत 30 से अधिक है।

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>40.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>

books.xqy

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

XQueryTester.java

package com.tutorialspoint.xquery;

import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.InputStream;

import javax.xml.xquery.XQConnection;
import javax.xml.xquery.XQDataSource;
import javax.xml.xquery.XQException;
import javax.xml.xquery.XQPreparedExpression;
import javax.xml.xquery.XQResultSequence;

import com.saxonica.xqj.SaxonXQDataSource;

public class XQueryTester {
   public static void main(String[] args){
      try {
         execute();
      }
      
      catch (FileNotFoundException e) {
         e.printStackTrace();
      }
      
      catch (XQException e) {
         e.printStackTrace();
      }
   }

   private static void execute() throws FileNotFoundException, XQException{
      InputStream inputStream = new FileInputStream(new File("books.xqy"));
      XQDataSource ds = new SaxonXQDataSource();
      XQConnection conn = ds.getConnection();
      XQPreparedExpression exp = conn.prepareExpression(inputStream);
      XQResultSequence result = exp.executeQuery();
      
      while (result.next()) {
         System.out.println(result.getItemAsString(null));
      }
   }	
}

एक्सएमएल एक्सएमएल के खिलाफ एक्सक्यूट करने के लिए कदम

  • Step 1 - XQueryTester.java को किसी भी स्थान पर कॉपी करें, कहें, E: > java

  • Step 2 - एक ही स्थान पर Books.xml की प्रतिलिपि बनाएँ, E: > java

  • Step 3 - कॉपी किताबें। एक ही स्थान पर, E: > java

  • Step 4- कंसोल का उपयोग करके XQueryTester.java संकलित करें। सुनिश्चित करें कि आपके पास JDK 1.5 है या बाद में आपकी मशीन पर स्थापित किया गया है और क्लासपैथ कॉन्फ़िगर किए गए हैं। JAVA का उपयोग करने के तरीके के विवरण के लिए, हमारे JAVA ट्यूटोरियल देखें

E:\java\javac XQueryTester.java
  • Step 5 - एक्सक्यूटेस्टर निष्पादित करें

E:\java\java XQueryTester

उत्पादन

आपको निम्न परिणाम प्राप्त होंगे -

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

उदाहरण को समझना

  • books.xml नमूना डेटा का प्रतिनिधित्व करता है।

  • books.xqy XQuery अभिव्यक्ति का प्रतिनिधित्व करता है जिसे books.xml पर निष्पादित किया जाना है। हम अगले अध्याय में विवरण में अभिव्यक्ति को समझेंगे।

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

FLWOR एक संक्षिप्त नाम है जो "For, Let, Where, Order by, Return" के लिए है। निम्न सूची से पता चलता है कि वे एक फ़्लॉवर अभिव्यक्ति में क्या खाते हैं -

  • F - के लिए - सभी नोड्स का एक संग्रह का चयन करता है।

  • L - आज्ञा देना एक XQuery चर में परिणाम डालता है।

  • W - कहाँ - हालत द्वारा निर्दिष्ट नोड्स का चयन करता है।

  • O - द्वारा आदेश - मापदंड के अनुसार निर्दिष्ट नोड का आदेश।

  • R - रिटर्न - अंतिम परिणाम लौटाता है।

उदाहरण

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

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 दस्तावेज़ में एक्सएमएल दस्तावेज़ के ऊपर दिए गए क्वेरी एक्सप्रेशन हैं।

books.xqy

let $books := (doc("books.xml")/books/book) return <results> { for $x in $books where $x/price>30
   order by $x/price return $x/title
}
</results>

परिणाम

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

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

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

एक्सएमएल दस्तावेज़ को आसानी से एक्सएमएल दस्तावेज़ को HTML पृष्ठ में बदलने के लिए भी इस्तेमाल किया जा सकता है। XQuery यह कैसे करता है यह समझने के लिए निम्नलिखित उदाहरण पर एक नज़र डालें।

उदाहरण

हम एक ही books.xml फ़ाइल का उपयोग करेंगे। निम्नलिखित उदाहरण Books.xml से XQuery एक्सट्रेक्ट डेटा का उपयोग करता है और एक HTML तालिका बनाता है जिसमें सभी पुस्तकों के शीर्षक के साथ-साथ उनके संबंधित मूल्य भी होते हैं।

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>

नीचे दिया गया एक्सक्वेरी अभिव्यक्ति है जिसे उपरोक्त एक्सएमएल दस्तावेज़ पर निष्पादित किया जाना है।

books.xqy

let $books := (doc("books.xml")/books/book) return <table><tr><th>Title</th><th>Price</th></tr> { for $x in $books order by $x/price
   return <tr><td>{data($x/title)}</td><td>{data($x/price)}</td></tr>
}
</table>
</results>

परिणाम

<table>
   <tr>
      <th>Title</th>
      <th>Price</th>
   </tr>
   <tr>
      <td>Learn XPath in 24 hours</td>
      <td>16.50</td>
   </tr>   
   <tr>
      <td>Learn Java in 24 Hours</td>
      <td>30.00</td>
   </tr>
   <tr>
      <td>Learn XQuery in 24 hours</td>
      <td>50.00</td>
   </tr>   
   <tr>
      <td>Learn .Net in 24 hours</td>
      <td>70.50</td>
   </tr>
</table>

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

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

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

यहां हमने निम्नलिखित XQuery अभिव्यक्तियों का उपयोग किया है -

  • शीर्षक तत्व के मूल्य का मूल्यांकन करने के लिए डेटा () फ़ंक्शन और

  • {} ऑपरेटर एक फ़ंक्शन के रूप में डेटा () पर विचार करने के लिए XQuery प्रोसेसर को बताने के लिए। यदि {} ऑपरेटर का उपयोग नहीं किया जाता है, तो डेटा () को सामान्य पाठ के रूप में माना जाएगा।

XQuery XPath का अनुपालन है। यह XML संग्रहों पर खोज परिणामों को प्रतिबंधित करने के लिए XPath अभिव्यक्तियों का उपयोग करता है। XPath का उपयोग कैसे करें के बारे में अधिक जानकारी के लिए, हमारे XPath ट्यूटोरियल देखें ।

निम्नलिखित XPath अभिव्यक्ति को याद करें जिसका उपयोग हमने पुस्तकों की सूची प्राप्त करने के लिए पहले किया है।

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

XPath उदाहरण

हम Books.xml फ़ाइल का उपयोग करेंगे और उस पर XQuery लागू करेंगे।

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>40.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 स्टेटमेंट के तीन संस्करण दिए हैं जो कि 30 से अधिक मूल्य वाले पुस्तक के शीर्षक को प्रदर्शित करने के एक ही उद्देश्य को पूरा करते हैं।

XQuery - संस्करण 1

(: read the entire xml document :)
let $books := doc("books.xml") for $x in $books/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 - संस्करण 2

(: read all books :)
let $books := doc("books.xml")/books/book

for $x in $books
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 - संस्करण 3

(: read books with price > 30 :)
let $books := doc("books.xml")/books/book[price > 30] for $x in $books 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 जावा प्रोग्राम को निष्पादित करें।

अनुक्रम उन वस्तुओं के ऑर्डर किए गए संग्रह का प्रतिनिधित्व करते हैं जहां आइटम समान या विभिन्न प्रकार के हो सकते हैं।

अनुक्रम बनाना

कोट्स या डबल कोट्स और संख्याओं के अंदर स्ट्रिंग्स के साथ कोष्ठक का उपयोग करके अनुक्रम बनाए जाते हैं। XML तत्वों का उपयोग अनुक्रम के आइटम के रूप में भी किया जा सकता है।

XQuery अभिव्यक्ति

let $items := ('orange', <apple/>, <fruit type="juicy"/>, <vehicle type="car">sentro</vehicle>, 1,2,3,'a','b',"abc") let $count := count($items) return <result> <count>{$count}</count>
   
   <items>
      {
	     for $item in $items
         return <item>{$item}</item>
      }
   </items>
   
</result>

उत्पादन

<result>
   <count>10</count>
   <items>
      <item>orange</item>
      <item>
         <apple/>
      </item>
      <item>
         <fruit type="juicy"/>
      </item>
      <item>
         <vehicle type="car">Sentro</vehicle>
      </item>
      <item>1</item>
      <item>2</item>
      <item>3</item>
      <item>a</item>
      <item>b</item>
      <item>abc</item>
   </items>
</result>

एक अनुक्रम की वस्तुओं को देखने

एक अनुक्रम की वस्तुओं को एक-एक करके, सूचकांक या मूल्य के आधार पर पुनरावृत्त किया जा सकता है। उपरोक्त उदाहरण ने एक-एक करके अनुक्रमों की वस्तुओं को पुनरावृत्त किया। आइए कार्रवाई में अन्य दो तरीके देखें।

XQuery अभिव्यक्ति (सूचकांक)

let $items := (1,2,3,4,5,6)
let $count := count($items)
return
   <result>
      <count>{$count}</count> <items> { for $item in $items[2] return <item>{$item}</item>
      }
      </items>
      
   </result>

उत्पादन

<result>
   <count>6</count>
   <items>
      <item>2</item>
   </items>
</result>

XQuery अभिव्यक्ति (मूल्य)

let $items := (1,2,3,4,5,6) let $count := count($items) return <result> <count>{$count}</count>
      
      <items>
      {
         for $item in $items[. = (1,2,3)]
         return <item>{$item}</item>
      }
      </items>
      
   </result>

उत्पादन

<result>
   <count>6</count>
   <items>
      <item>1</item>
      <item>2</item>
      <item>3</item>
   </items>
</result>

निम्न तालिका XQuery द्वारा प्रदान किए गए सामान्यतः उपयोग किए जाने वाले अनुक्रम कार्यों को सूचीबद्ध करती है।

अनु क्रमांक नाम और विवरण
1

गणना (आइटम के रूप में $ seq) (*)

एक क्रम में आइटम गिना जाता है।

2

योग (आइटम के रूप में $ seq) () *

एक क्रम में वस्तुओं का योग देता है।

3

avg (आइटम के रूप में $ seq () *)

एक क्रम में वस्तुओं का औसत लौटाता है।

4

मिनट (आइटम के रूप में $ seq) () *

एक अनुक्रम में न्यूनतम मूल्यवान वस्तु देता है।

5

अधिकतम (आइटम के रूप में $ seq) () *

एक अनुक्रम में अधिकतम मूल्यवान वस्तु लौटाता है।

6

अलग-अलग मूल्य (आइटम के रूप में $ seq) () *

रिटर्न एक क्रम से अलग आइटम का चयन करते हैं।

7

बाद में (आइटम के रूप में $ seq) (*, $startingLoc as xs:double, $लंबाई के रूप में एक्स: डबल)

दिए गए अनुक्रम का एक सबसेट लौटाता है।

8

सम्मिलित-से पहले ($seq as item()*, $एक्स के रूप में स्थिति: पूर्णांक, आइटम के रूप में $ आवेषण () *)

एक अनुक्रम में एक आइटम सम्मिलित करता है।

9

निकालें (आइटम के रूप में $ seq) (*, x के रूप में $ स्थिति: पूर्णांक)

किसी आइटम को अनुक्रम से निकालता है।

10

रिवर्स (आइटम के रूप में $ seq) () *

उलटा क्रम लौटाता है।

1 1

के सूचकांक($seq as anyAtomicType()*, $anyAtomicType () के रूप में लक्ष्य

अनुक्रम के भीतर किसी आइटम की उपलब्धता को इंगित करने के लिए पूर्णांक के रूप में अनुक्रमित करता है।

12

पिछले ()

एक अनुक्रम के अंतिम तत्व को जब विधेय अभिव्यक्ति में उपयोग किया जाता है।

13

पद()

किसी क्रम में किसी वस्तु की स्थिति प्राप्त करने के लिए FLOWR अभिव्यक्तियों में प्रयुक्त।

निम्न तालिका XQuery द्वारा प्रदान की जाने वाली आमतौर पर उपयोग किए जाने वाले स्ट्रिंग हेरफेर कार्यों को सूचीबद्ध करती है।

अनु क्रमांक नाम और विवरण
1

string-length ($ string as xs: string) xs: पूर्णांक

स्ट्रिंग की लंबाई लौटाता है।

2

concat ($ input as xs: anyAtomicType?) xs: string के रूप में

आउटपुट के रूप में समतल स्ट्रिंग लौटाता है।

3

स्ट्रिंग से शामिल ($sequence as xs:string*, $delimiter as xs: string) xs के रूप में: स्ट्रिंग

एक सीमांकक द्वारा अलग किए गए अनुक्रम में वस्तुओं के संयोजन को लौटाता है।

निम्न तालिका XQuery द्वारा प्रदान की जाने वाली आमतौर पर उपयोग की जाने वाली तिथि कार्यों को सूचीबद्ध करती है।

अनु क्रमांक नाम और विवरण
1

आज की तारीख()

वर्तमान दिनांक लौटाता है।

2

वर्तमान समय()

वर्तमान समय लौटाता है।

3

वर्तमान dateTime ()

वर्तमान तिथि और वर्तमान समय दोनों देता है।

निम्नलिखित XQuery द्वारा प्रदान की जाने वाली सामान्य रूप से उपयोग की जाने वाली नियमित अभिव्यक्ति कार्यों की सूची है

अनु क्रमांक नाम और विवरण
1

मैचों ($input, $regex)

यदि इनपुट नियमित रूप से दिए गए अभिव्यक्ति के साथ मेल खाता है तो सही है।

2

बदलने के($input, $रेगेक्स, $ स्ट्रिंग)

दिए गए स्ट्रिंग के साथ मिलान किए गए इनपुट स्ट्रिंग को बदलता है।

3

टोकन ($ इनपुट, $ रेगेक्स)

नियमित अभिव्यक्ति से मेल खाते आइटम का एक क्रम देता है।

XQuery एक बहुत उपयोगी प्रदान करता है अगर-तब निर्माण इनपुट मूल्यों की वैधता की जांच करने के लिए। नीचे दिए गए if-if-अन्यथा निर्माण का सिंटैक्स है।

वाक्य - विन्यास

if (condition) then
 ... 
else
 ...

उदाहरण

हम निम्नलिखित Books.xml फ़ाइल का उपयोग करेंगे और उस पर लागू करेंगे XQuery की अभिव्यक्ति जिसमें एक if-else का निर्माण होता है, उन पुस्तकों के शीर्षकों को एक मूल्य मूल्य के साथ पुनर्प्राप्त करने के लिए जो 30 से अधिक है।

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>40.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 दस्तावेज़ पर लागू किया जाना है।

books.xqy

<result>
{
   if(not(doc("books.xml"))) then (
      <error>
         <message>books.xml does not exist</message>
      </error>
   )
   else ( 
      for $x in doc("books.xml")/books/book	
      where $x/price>30 return $x/title
   )
}
</result>

उत्पादन

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

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

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

XQuery कस्टम फ़ंक्शन लिखने की क्षमता प्रदान करता है। नीचे सूचीबद्ध एक कस्टम फ़ंक्शन बनाने के लिए दिशानिर्देश हैं।

  • कीवर्ड का उपयोग करें declare function एक समारोह को परिभाषित करने के लिए।

  • वर्तमान XML स्कीमा में परिभाषित डेटा प्रकारों का उपयोग करें

  • घुंघराले ब्रेस के अंदर फ़ंक्शन के शरीर को संलग्न करें।

  • एक्सएमएल नेमस्पेस के साथ फ़ंक्शन का नाम प्रीफ़िक्स करें।

कस्टम फ़ंक्शन बनाते समय निम्न सिंटैक्स का उपयोग किया जाता है।

वाक्य - विन्यास

declare function prefix:function_name($parameter as datatype?...)
as returnDatatype?
{
   function body...
};

उदाहरण

निम्न उदाहरण दिखाता है कि XQuery में उपयोगकर्ता-परिभाषित फ़ंक्शन कैसे बनाया जाए।

XQuery अभिव्यक्ति

declare function local:discount($price as xs:decimal?,$percentDiscount as xs:decimal?) as xs:decimal? { let $discount := $price - ($price * $percentDiscount div 100) return $discount
};

let $originalPrice := 100 let $discountAvailed := 10

return ( local:discount($originalPrice, $discountAvailed))

उत्पादन

90

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

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