XQuery 序列函数 insert-before()函数

XQuery 序列函数 insert-before()函数 介绍

insert-before函数用于在任何位置的给定序列中插入一个项。此函数返回修改后的序列,但原始序列未更改。

XQuery 序列函数 insert-before()函数 语法

insert-before($seq as item()*, $position as xs:integer, $inserts as item()*)

XQuery 序列函数 insert-before()函数 参数

  • $seq : 提供的序列。序列可以包含 0 个或多个项目。

  • $position : 要插入的项目的索引。索引从 1 开始。

  • $inserts : 要插入的零个或多个项目。

XQuery 序列函数 insert-before()函数 示例

XQuery 表达式

items.xqy:

let $items := (1,2,3,4,5,9)
let $additional-items := (6,7,8)
let $new-items := insert-before($items,6,$additional-items)
return
   <result>

      <items>
            {
               for $item in $new-items
               return <item>{$item}</item>
            }
      </items>

   </result>

解析程序

package com.yiidian;

import com.saxonica.xqj.SaxonXQDataSource;

import javax.xml.xquery.*;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.InputStream;

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

输出结果为:

热门文章

优秀文章