📜  XQuery语法

📅  最后修改于: 2020-12-25 05:01:28             🧑  作者: Mango

XQuery语法

XQuery元素,属性和变量必须是有效的XML名称,并且必须区分大小写。

XQuery语法规则

  • XQuery区分大小写。
  • XQuery元素,属性和变量必须是有效的XML名称。
  • XQuery字符串值可以用单引号或双引号引起来。
  • XQuery变量定义为$,后跟名称,例如:。 $ bookstore
  • XQuery注释由(:和:)分隔,例如(:: XQuery Comment 🙂

我们来看一个具有以下数据的XML文件'books.xml':



If she loves me
Ajeet Kumar
2014
150


Harry Potter
J K. Rowling
2005
700


Let's C
Yashwant Kanetkar
2003
200


XQuery条件表达式

XQuery中允许使用“ If-Then-Else”条件语句。

XQuery语句:

books.xqy

for $x in doc("books.xml")/bookstore/book
return if ($x/@category="CHILDREN")
then {data($x/title)}
else {data($x/title)}

怎么跑

创建一个基于Java的XQuery执行程序,以读取books.xqy,将其传递给XQuery表达式处理器,并执行该表达式。之后,将显示结果。

XQueryTester.java

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("courses.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));
      }
   }    
}

对XML执行XQuery

将以上三个文件放在同一位置。我们将它们放在桌面上的文件夹名称XQuery6中。

使用控制台编译XQueryTester.java。您必须在计算机上安装JDK 1.5或更高版本,并且已配置类路径。

编译:

javac XQueryTester.java

执行:

Java XQueryTester

输出:

XQuery比较

比较XQuery中的值有两种类型。

  • 常规比较: =,!=,<,<=,>,> =
  • 值比较: eq,ne,lt,le,gt,ge

一般比较和价值比较之间的区别

可以用一个例子来解释。如果任何q属性的值都大于100,则以下表达式返回true。

$bookstore//book/@q > 100 

如果该表达式仅返回一个q属性,并且其值大于10,则以下表达式返回true。如果返回多个q,则会发生错误:

$bookstore//book/@q gt 100