XQuery - Panduan Cepat

Apa itu XQuery

XQuery adalah bahasa fungsional yang digunakan untuk mengambil informasi yang disimpan dalam format XML. XQuery dapat digunakan pada dokumen XML, database relasional yang berisi data dalam format XML, atau Database XML. XQuery 3.0 adalah rekomendasi W3C mulai 8 April 2014.

Definisi XQuery seperti yang diberikan oleh dokumentasi resminya adalah sebagai berikut -

XQuery adalah bahasa standar untuk menggabungkan dokumen, database, halaman Web, dan hampir semua hal lainnya. Ini diterapkan secara luas. Ini sangat kuat dan mudah dipelajari. XQuery menggantikan bahasa middleware berpemilik dan bahasa pengembangan Aplikasi Web. XQuery menggantikan program Java atau C ++ yang kompleks dengan beberapa baris kode. XQuery lebih sederhana untuk dikerjakan dan lebih mudah dipelihara daripada banyak alternatif lainnya.

Karakteristik

  • Functional Language - XQuery adalah bahasa untuk mengambil / menanyakan data berbasis XML.

  • Analogous to SQL - XQuery adalah XML apa SQL itu database.

  • XPath based - XQuery menggunakan ekspresi XPath untuk menavigasi dokumen XML.

  • Universally accepted - XQuery didukung oleh semua database utama.

  • W3C Standard - XQuery adalah standar W3C.

Manfaat XQuery

  • Dengan menggunakan XQuery, data hierarki dan tabular dapat diambil.

  • XQuery dapat digunakan untuk query struktur pohon dan grafis.

  • XQuery dapat langsung digunakan untuk menanyakan halaman web.

  • XQuery dapat langsung digunakan untuk membangun halaman web.

  • XQuery dapat digunakan untuk mengubah dokumen xml.

  • XQuery sangat ideal untuk database berbasis XML dan database berbasis objek. Database objek jauh lebih fleksibel dan kuat daripada database tabel murni.

Bab ini menjelaskan cara menyiapkan pustaka XQuery di lingkungan pengembangan lokal.

Kami menggunakan prosesor XQuery mandiri open source Saxon Home Edition (Saxon-HE) yang banyak digunakan. Prosesor ini mendukung XSLT 2.0, XQuery 3.0, dan XPath 3.0 dan sangat dioptimalkan untuk kinerja. Prosesor Saxon XQuery dapat digunakan tanpa memiliki database XML. Kami akan menggunakan dokumen XML sederhana sebagai database kami dalam contoh kami.

Untuk menggunakan prosesor Saxon XQuery, Anda harus memiliki saxon9he.jar, saxon9-test.jar, saxon9-unpack, saxon9-xqj.jar di jalur kelas aplikasi Anda. File jar ini tersedia di file unduhanSaxonHE9-6-0-1J.zipUnduh SaxonHE9-6-0-1J.zip .

Contoh

Kami akan menggunakan prosesor Saxon XQuery berbasis Java untuk menguji books.xqy, file yang berisi ekspresi XQuery terhadap dokumen XML sampel kami, yaitu books.xml.

Dalam contoh ini, kita akan melihat cara menulis dan memproses kueri untuk mendapatkan elemen judul buku yang harganya lebih dari 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));
      }
   }	
}

Langkah-langkah untuk Menjalankan XQuery terhadap XML

  • Step 1 - Salin XQueryTester.java ke lokasi mana pun, katakanlah, E: > java

  • Step 2 - Salin books.xml ke lokasi yang sama, E: > java

  • Step 3 - Salin books.xqy ke lokasi yang sama, E: > java

  • Step 4- Kompilasi XQueryTester.java menggunakan konsol. Pastikan Anda memiliki JDK 1.5 atau yang lebih baru diinstal pada mesin Anda dan classpath telah dikonfigurasi. Untuk detail tentang cara menggunakan JAVA, lihat Tutorial JAVA kami

E:\java\javac XQueryTester.java
  • Step 5 - Jalankan XQueryTester

E:\java\java XQueryTester

Keluaran

Anda akan mendapatkan hasil sebagai berikut -

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

Memahami Contoh

  • books.xml mewakili data sampel.

  • books.xqy mewakili ekspresi XQuery yang akan dieksekusi di books.xml. Kami akan memahami ekspresi secara rinci di bab berikutnya.

  • XQueryTester, program eksekutor XQuery berbasis Java, membaca books.xqy, meneruskannya ke prosesor ekspresi XQuery, dan mengeksekusi ekspresi tersebut. Kemudian hasilnya dicetak.

Contoh

Berikut adalah contoh dokumen XML yang berisi catatan dari sebuah toko buku dari berbagai buku.

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>

Berikut ini adalah contoh dokumen Xquery yang berisi ekspresi query untuk dieksekusi pada dokumen XML di atas. Tujuannya adalah untuk mendapatkan elemen judul dari node XML yang harganya lebih dari 30.

books.xqy

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

Hasil

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

Verifikasi Hasil

Untuk memverifikasi hasilnya, ganti konten books.xqy (diberikan di bab Pengaturan Lingkungan ) dengan ekspresi XQuery di atas dan jalankan program java XQueryTester.

Ekspresi XQuery

Mari kita pahami setiap bagian dari ekspresi XQuery di atas.

Penggunaan fungsi

doc("books.xml")

doc () adalah salah satu fungsi XQuery yang digunakan untuk menemukan sumber XML. Di sini kami telah melewati "books.xml". Mempertimbangkan jalur relatif, books.xml harus berada di jalur yang sama dengan tempat books.xqy ada.

Penggunaan ekspresi XPath

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

XQuery sangat menggunakan ekspresi XPath untuk menemukan bagian XML yang diperlukan untuk melakukan pencarian. Di sini kami telah memilih semua node buku yang tersedia di bawah node buku.

Iterasi objek

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

XQuery memperlakukan data xml sebagai objek. Dalam contoh di atas, $ x mewakili node yang dipilih, sedangkan for loop melakukan iterasi atas kumpulan node.

Terapkan kondisinya

where $x/price>30

Karena $ x mewakili node yang dipilih, "/" digunakan untuk mendapatkan nilai elemen yang diperlukan; Klausa "di mana" digunakan untuk memberi kondisi pada hasil pencarian.

Kembalikan hasilnya

return $x/title

Karena $ x mewakili node yang dipilih, "/" digunakan untuk mendapatkan nilai elemen yang diperlukan, harga, judul; Klausa "return" digunakan untuk mengembalikan elemen dari hasil pencarian.

FLWOR adalah singkatan dari "For, Let, Where, Order by, Return". Daftar berikut menunjukkan apa yang mereka perhitungkan dalam ekspresi FLWOR -

  • F - Untuk - Memilih kumpulan dari semua node.

  • L - Let - Menempatkan hasil dalam variabel XQuery.

  • W - Where - Memilih node yang ditentukan oleh kondisi.

  • O - Diurutkan berdasarkan - Mengurutkan node yang ditentukan sesuai kriteria.

  • R - Return - Mengembalikan hasil akhir.

Contoh

Berikut ini adalah contoh dokumen XML yang berisi informasi tentang kumpulan buku. Kami akan menggunakan ekspresi FLWOR untuk mengambil judul buku-buku tersebut dengan harga lebih dari 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>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>

Dokumen Xquery berikut berisi ekspresi query untuk dieksekusi pada dokumen XML di atas.

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>

Hasil

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

Verifikasi Hasil

Untuk memverifikasi hasilnya, ganti konten books.xqy (diberikan di bab Pengaturan Lingkungan ) dengan ekspresi XQuery di atas dan jalankan program java XQueryTester.

XQuery juga dapat dengan mudah digunakan untuk mengubah dokumen XML menjadi halaman HTML. Lihat contoh berikut untuk memahami bagaimana XQuery melakukannya.

Contoh

Kami akan menggunakan file books.xml yang sama. Contoh berikut menggunakan data ekstrak XQuery dari books.xml dan membuat tabel HTML yang berisi judul semua buku beserta harganya masing-masing.

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>

Diberikan di bawah ini adalah ekspresi Xquery yang akan dieksekusi pada dokumen XML di atas.

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>

Hasil

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

Verifikasi Hasil

Untuk memverifikasi hasilnya, ganti konten books.xqy (diberikan di bab Pengaturan Lingkungan ) dengan ekspresi XQuery di atas dan jalankan program java XQueryTester.

Ekspresi XQuery

Di sini kami telah menggunakan ekspresi XQuery berikut -

  • data () berfungsi untuk mengevaluasi nilai elemen judul, dan

  • {} operator untuk memberi tahu prosesor XQuery untuk mempertimbangkan data () sebagai fungsi. Jika operator {} tidak digunakan, maka data () akan diperlakukan sebagai teks normal.

XQuery kompatibel dengan XPath. Ini menggunakan ekspresi XPath untuk membatasi hasil pencarian pada koleksi XML. Untuk detail lebih lanjut tentang cara menggunakan XPath, lihat Tutorial XPath kami .

Ingat ekspresi XPath berikut yang telah kita gunakan sebelumnya untuk mendapatkan daftar buku.

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

Contoh XPath

Kami akan menggunakan file books.xml dan menerapkan XQuery padanya.

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>

Di sini kami telah memberikan tiga versi pernyataan XQuery yang memenuhi tujuan yang sama untuk menampilkan judul buku yang memiliki nilai harga lebih dari 30.

XQuery - Versi 1

(: read the entire xml document :)
let $books := doc("books.xml") for $x in $books/books/book where $x/price > 30
return $x/title

Keluaran

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

XQuery - Versi 2

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

for $x in $books
where $x/price > 30 return $x/title

Keluaran

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

XQuery - Versi 3

(: read books with price > 30 :)
let $books := doc("books.xml")/books/book[price > 30] for $x in $books return $x/title

Keluaran

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

Verifikasi Hasilnya

Untuk memverifikasi hasilnya, ganti konten books.xqy (diberikan di bab Pengaturan Lingkungan ) dengan ekspresi XQuery di atas dan jalankan program java XQueryTester.

Urutan mewakili kumpulan item yang dipesan di mana item bisa serupa atau dari jenis yang berbeda.

Membuat Urutan

Urutan dibuat menggunakan tanda kurung dengan string di dalam tanda kutip atau tanda kutip ganda dan angka seperti itu. Elemen XML juga bisa digunakan sebagai item dari suatu urutan.

Ekspresi 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>

Keluaran

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

Melihat Item Urutan

Item dari suatu urutan dapat diiterasi satu per satu, menggunakan indeks atau nilai. Contoh di atas mengulang item-item dari suatu urutan satu per satu. Mari kita lihat dua cara lain dalam beraksi.

Ekspresi XQuery (Indeks)

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>

Keluaran

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

XQuery Expression (Nilai)

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>

Keluaran

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

Tabel berikut mencantumkan fungsi urutan yang umum digunakan yang disediakan oleh XQuery.

Sr Tidak Nama & Deskripsi
1

hitung ($ seq sebagai item () *)

Menghitung item secara berurutan.

2

jumlah ($ seq sebagai item () *)

Mengembalikan jumlah item secara berurutan.

3

rata-rata ($ seq sebagai item () *)

Mengembalikan rata-rata item secara berurutan.

4

min ($ seq sebagai item () *)

Mengembalikan item bernilai minimum secara berurutan.

5

maks ($ seq sebagai item () *)

Mengembalikan item bernilai maksimum secara berurutan.

6

nilai-berbeda ($ seq sebagai item () *)

Kembali memilih item yang berbeda dari urutan.

7

urutan ($ seq sebagai item () *, $startingLoc as xs:double, $panjang sebagai xs: double)

Menampilkan subset dari urutan yang disediakan.

8

masukkan-sebelum ($seq as item()*, $posisi sebagai xs: integer, $ inserts as item () *)

Menyisipkan item secara berurutan.

9

hapus ($ seq sebagai item () *, $ posisi sebagai xs: integer)

Menghapus item dari urutan.

10

kebalikan ($ seq sebagai item () *)

Mengembalikan urutan yang dibalik.

11

Indeks($seq as anyAtomicType()*, $targetkan sebagai anyAtomicType ())

Mengembalikan indeks sebagai bilangan bulat untuk menunjukkan ketersediaan item dalam suatu urutan.

12

terakhir()

Mengembalikan elemen terakhir dari sebuah urutan saat digunakan dalam ekspresi predikat.

13

posisi()

Digunakan dalam ekspresi FLOWR untuk mendapatkan posisi item secara berurutan.

Tabel berikut mencantumkan fungsi manipulasi string yang umum digunakan yang disediakan oleh XQuery.

Sr Tidak Nama & Deskripsi
1

string-length ($ string sebagai xs: string) sebagai xs: integer

Mengembalikan panjang string.

2

concat ($ input sebagai xs: anyAtomicType?) sebagai xs: string

Mengembalikan string gabungan sebagai output.

3

string-join ($sequence as xs:string*, $pembatas sebagai xs: string) sebagai xs: string

Mengembalikan kombinasi item dalam urutan yang dipisahkan oleh pemisah.

Tabel berikut mencantumkan fungsi tanggal yang umum digunakan yang disediakan oleh XQuery.

Sr Tidak Nama & Deskripsi
1

tanggal sekarang()

Mengembalikan tanggal sekarang.

2

waktu saat ini()

Mengembalikan waktu saat ini.

3

current-dateTime ()

Menampilkan tanggal sekarang dan waktu sekarang.

Berikut adalah daftar fungsi ekspresi reguler yang umum digunakan yang disediakan oleh XQuery

Sr Tidak Nama & Deskripsi
1

pertandingan ($input, $ekspresi reguler)

Mengembalikan nilai benar jika masukan cocok dengan ekspresi reguler yang disediakan.

2

menggantikan($input, $ekspresi reguler, $ string)

Mengganti string input yang cocok dengan string yang diberikan.

3

tokenize ($ input, $ regex)

Mengembalikan urutan item yang cocok dengan ekspresi reguler.

XQuery menyediakan konstruksi if-then-else yang sangat berguna untuk memeriksa validitas nilai input yang diteruskan. Diberikan di bawah ini adalah sintaks dari konstruksi if-then-else.

Sintaksis

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

Contoh

Kami akan menggunakan file books.xml berikut dan menerapkannya ke ekspresi XQuery yang berisi konstruksi if-then-else untuk mengambil judul buku tersebut dengan nilai harga yang lebih besar dari 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>

Ekspresi XQuery berikut akan diterapkan pada dokumen XML di atas.

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>

Keluaran

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

Verifikasi Hasilnya

Untuk memverifikasi hasilnya, ganti konten books.xqy (diberikan di bab Pengaturan Lingkungan ) dengan ekspresi XQuery di atas dan jalankan program java XQueryTester.

XQuery menyediakan kemampuan untuk menulis fungsi kustom. Di bawah ini adalah daftar panduan untuk membuat fungsi kustom.

  • Gunakan kata kunci declare function untuk mendefinisikan suatu fungsi.

  • Gunakan tipe data yang ditentukan dalam Skema XML saat ini

  • Lampirkan fungsi tubuh di dalam kurung kurawal.

  • Awali nama fungsi dengan namespace XML.

Sintaks berikut digunakan saat membuat fungsi kustom.

Sintaksis

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

Contoh

Contoh berikut menunjukkan cara membuat fungsi yang ditentukan pengguna di XQuery.

Ekspresi 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))

Keluaran

90

Verifikasi Hasilnya

Untuk memverifikasi hasilnya, ganti konten books.xqy (diberikan di bab Pengaturan Lingkungan ) dengan ekspresi XQuery di atas dan jalankan program java XQueryTester.