XQuery Tutorial – FLWOR expression

The XQuery Tutorial covers the topics on Xquery Functions, XQuery FLWOR, XQuery Syntax, XQuery Add, XQuery Select , extracting elements and attributes from XML documents, transform XML data to XHTML, XPath Operators , XPath Functions, XQuery Data Types, XQuery User-Defined Functions.

Letd discuss FLWOR expression in detail.

Xquery Tutorial on XQuery FLOWR expression shows how to binding XML nodes, XML sequences to variable, sorting the nodes and expected node return value.

What is FLWOR expression in XQuery ?

FLWOR is an acronym for “For, Let, Where, Order by, Return”. FLWOR is pronounced as “flower”.

For – selects the sequence of nodes
Let – binds the sequence to a variable
Where – use for nodes filtering
Order by – use for nodes sorting
Return – what to return

XQuery FLWOR node retrieval example

Lets consider the below given “order.xml” file and try to get the node retrieval based on price check where price for the order <30.

XQuery FLWOR Expression for price check:

doc(“order.xml”)/oracleappshelpOrder/order[price< 30]/orderId

The XQuery FLWOR Expression returns same result as per the below XQuery XPath expression

for $x in doc(“order.xml”)/oracleappshelpOrder/order
where $x/price<30
return $x/orderId

Xquery Output:

<orderId>12346</orderId>

<orderId>12347</orderId>

<oracleappshelpOrder>
<Order>
    <orderId>12345</orderId>
    <quantity>1</quantity>
  	<price>40<price>
</Order>
<Order>
    <orderId>12346</orderId>
    <quantity>1</quantity>
  	<price>25<price>
</Order>
<Order>
    <orderId>12347</orderId>
    <quantity>1</quantity>
  	<price>28<price>
</Order>
</oracleappshelpOrder>

XQuery FLWOR into HTML

Now , we can use the basic list tag to discplay the data into HTML

<ul>
for $x in doc("order.xml")/oracleappshelpOrder/order/orderId
order by $x
return <li>{$x}</li>
}
</ul> 

<ul>

<li><orderId>12346</orderId></li>

<li> <orderId>12347</orderId> </li>

</ul>

We can also list the actual data without the orderId tag by using the data ($x)

<ul>
for $x in doc("order.xml")/oracleappshelpOrder/order/orderId
order by $x
return <li>{data{$x}}</li>
}
</ul> 

The output will be :

<ul>

<li>12346</li>

<li>12347</li>

</ul>


XQuery Tutorial – Overview

The XQuery Tutorial covers the topics on Xquery Functions, XQuery FLWOR, XQuery Syntax, XQuery Add, XQuery Select , extracting elements and attributes from XML documents, transform XML data to XHTML, XPath Operators , XPath Functions, XQuery Data Types, XQuery User-Defined Functions.

Lets discuss XQuery in detail.

What is XQuery?

The XML data includes the XML elements or called XML “nodes” which should be valid and could be parsed in a well formed XML Document. The XML data need to be queried like we use SQL Query to Query the Database data.

Thus , XQuery is designed to help in Querying the XML data.

XQuery – Points to Consider

  1. XQuery is W3C recommedation and XQuery Version 1.0 is recommendation by W3C in 2007.
  2. XQuery is compatible with XML, Namespaces, XSLT, XPath, and XML Schema
  3. XQuery is the language used for querying the XML data
  4. XQuery is built on the XPath expressions

How XQuery is useful ?

The XQuery can be used for the below given reasons :

  1. XQuery is compatible with XML, Namespaces, XSLT, XPath, and XML Schema
  2. XQuery helps in extracting the information in a heterogeneous environment integrated using XML
  3. XQuery is useful in transforming the XML data to XHTML
  4. helps in searching web documents for the related information.
  5. XQuery helps in generating reports
<oracleappshelpuser>
<student>
    <firstName>Mohit</firstName>
    <lastName>Sharma</lastName>
  	<registered>Yes<registered>
</student>
<student>
    <firstName>Rahul</firstName>
    <lastName>Jain</lastName>
  	<registered>Yes<registered>
</student>
<student>
    <firstName>Abhishek</firstName>
    <lastName>Gupta</lastName>
  	<registered>No<registered>
</student>
</oracleappshelpuser>

XQuery – Retrieve XML Node data from XML Document

XQuery provides the XQuery Functions which are used for extracting / retrieving the XML Data from the XML “nodes” in the XML Document.

Example:

doc(“student.xml”) is the XQuery function to open the Student.xml file for Query the XML Document.

We will discuss more in detail for the Query Functions in the next blog.

XQuery – Navigate using XPath expressions

XQuery uses the in built XPath expressions for navigating to the XMl node in the XML Document

Example: If we need to navigate to the firstName node in the above provided student.xml , then the below expression should be used

doc(“student.xml”)/oracleappshelpuser/student/firstName

The XQuery output should be like:

    <firstName>Mohit</firstName>
	<firstName>Rahul</firstName>
	<firstName>Abhishek</firstName>

We will discuss more in detail for the Query XPath expression in the next blog.