MarkLogic Server XPath Quick Reference
5.0 XPath Quick Reference
71
The section provides a brief overview of the basics of XPath, and includes the following sections:
• Path Expressions
• XPath Axes and Syntax
• XPath 2.0 Functions
• Restricted XPath
For detailed information about XPath, see the W3C XPath 2.0 language reference
(http://www.w3.org/TR/xpath20/).
5.1 Path Expressions
XPath 2.0 is part of XQuery 1.0. XPath is used to navigate XML structures. In MarkLogic Server,
the XML structures can be stored in a database or they can be constructed in XQuery. A path
expression is an expression that selects nodes from an XML structure. Path expressions are a
fundamental way of identifying content in XQuery. Each path has zero or more steps, which
typically select XML nodes. Each step can have zero or more predicates, which constrain the
nodes that are selected. By combining multiple steps and predicates, you can create arbitrarily
complex path expressions. Consider the following path expression (which is in itself a valid
XQuery expression):
//LINE[fn:contains(., "To be, or not to be")]
Against the Shakespeare database (the XML is available at
http://www.oasis-open.org/cover/bosakShakespeare200.html), this XPath expression selects all LINE
elements that contain the text To be or not to be. You can then walk up the document to its
parent to see who says this line. as follows:
//LINE[fn:contains(., "To be, or not to be")]/../SPEAKER
This returns the following line:
<SPEAKER>HAMLET</SPEAKER>
You can make path expressions arbitrarily complex, which makes them a very powerful tool for
navigating through XML structures. For more details about path expressions, see the W3C
XQuery specification (http://www.w3.org/TR/xquery/#id-path-expressions).
MarkLogic 10—May, 2019 XQuery and XSLT Reference Guide—Page 56
MarkLogic Server XPath Quick Reference
A path expression always returns nodes in document order. If you want to return nodes in
relevance order (that is, relevance-ranked nodes), use the MarkLogic Server cts:search built-in
function or put the XPath in a FLWOR expression with an order by clause. Note that both XPath
expressions and cts:search expressions use any available indexes for fast expression evaluation.
For details on cts:search, see the Application Developer’s Guide and the MarkLogic XQuery and
XSLT Function Reference. For details about index options in MarkLogic Server, see the
Administrator’s Guide.
5.2 XPath Axes and Syntax
The following table shows the XPath axes supported in MarkLogic Server.
Shorthand (N/A
Axis Description
if no shorthand)
ancestor:: Selects all ancestor nodes, which N/A
includes the parent node, the parent’s
parent node, and so on.
ancestor-or-self:: Selects the current node as well as all N/A
ancestor nodes, which includes the
parent node, the parent’s parent node,
and so on.
attribute:: Selects the attributes of the current node. @
child:: Selects the immediate child nodes of the /
current node.
descendant:: Selects all descendant nodes (child N/A
nodes, their child nodes, and so on).
descendant-or-self:: Selects the current node as well as all //
descendant nodes (child nodes, their
child nodes, and so on).
following:: Selects everything following the current >>
node.
following-sibling:: Selects all sibling nodes (nodes at the N/A
same level in the XML hierarchy) that
come after the current node.
namespace:: Selects the namespace node of the N/A
current node.
MarkLogic 10—May, 2019 XQuery and XSLT Reference Guide—Page 57
MarkLogic Server XPath Quick Reference
Shorthand (N/A
Axis Description
if no shorthand)
parent:: Selects the immediate parent of the ..
current node.
preceding:: Selects everything before the current <<
node.
preceding-sibling:: Selects all sibling nodes (nodes at the N/A
same level in the XML hierarchy) that
come before the current node.
property:: MarkLogic Server enhancement. Selects N/A
the properties fragment corresponding to
the current node.
self:: Selects the current node (the context .
node).
Keep in mind the following notes when using the XPath axes:
• XPath expressions are always returned in document order.
• Axes that look forward return in document order (closest to farthest away from the context
node).
• Axes that look backward return in reverse document order (closest to farthest away from
the context node).
• The context node is the node from which XPath steps are evaluated. The context node is
sometimes called the current node.
5.3 XPath 2.0 Functions
The XQuery standard functions are the same as the XPath 2.0 functions. These XQuery-standard
functions are all built into MarkLogic Server, and use the namespace bound to the fn prefix,
which is predefined in MarkLogic Server. For details on these functions, see the MarkLogic
XQuery and XSLT Function Reference reference.
5.4 Restricted XPath
MarkLogic supports the full XPath 2.0 grammar (plus extensions) in most places where you can
specify an XPath expression. However, some evaluation contexts restrict you to a subset of XPath
for performance and/or security reasons.
MarkLogic 10—May, 2019 XQuery and XSLT Reference Guide—Page 58
MarkLogic Server XPath Quick Reference
The following features only support a restricted XPath subset. Each feature imposes different
limitations.
• Path Field and Path-Based Range Index Configuration
• Element Level Security
• Template Driven Extraction (TDE)
• Patch Feature of the Client APIs
• The extract-document-data Query Option
• The Optic API xpath Function
The following topics provide supporting details for the XPath restrictions applicable to these
features.
• Functions Callable in Predicate Expressions
• Indexable Path Expression Grammar
• Patch and Extract Path Expression Grammar
For detailed information about XPath, see the W3C XPath 2.0 language reference
(http://www.w3.org/TR/xpath20/).
5.4.1 Path Field and Path-Based Range Index Configuration
When you create a field or an index based on an XPath expression, these XPath expressions are
limited to the subset described here. This restriction applies to configuring the following:
• Path Range Index
• Field Range Index
• Geospatial Region Index
• Geospatial Path Index (a path-based point index)
To test an XPath expression for validity in these contexts, use the XQuery function
cts:valid-index-path or the Server-Side JavaScript function cts.validIndexPath.
Note: Avoid creating multiple path indexes that end with the same element/attribute, as
ingestion performance degrades with the number of path indexes that end in
common element/attributes.
The following list defines key aspects of the XPath restrictions. Additional restrictions may apply.
For a complete definition of the valid XPath subset, see “Indexable Path Expression Grammar” on
page 68.
• The only operators you can use in predicate expressions are comparison and logical
operators. (=, !=, <, <=, >=, >, eq, ne, lt, le, ge, gt, and, or).
MarkLogic 10—May, 2019 XQuery and XSLT Reference Guide—Page 59
MarkLogic Server XPath Quick Reference
• The right operand of a comparison in a predicate can only be a string literal, numeric
literal, or a sequence of string or numeric literals.
• You can only use forward axes in path steps. That is, you can use axes such as self::,
child::, descendant::, but you cannot use reverse axes such as parent::, ancestor::, or
preceding::. For details, see http://www.w3.org/TR/xpath/#predicates.
• You can only call functions on the “safe” function list in a predicate expression. For
details, see “Functions Callable in Predicate Expressions” on page 65.
• You cannot span a fragment root. Paths must be scoped within fragment roots.
• You cannot use an unnamed node test as the last path step. For example, when addressing
JSON, you cannot have a final path step such as node() or array-node(). You can use
named nodes, such as node('a').
The following table provides some examples of path expressions that meet the requirements of an
indexable path expression. This set of examples is not exhaustive.
Supported XPath Feature Valid Example
Absolute path /a/b
Relative path a/b
Intermediate path step containing a test for a /a/element(b)/c
named or unnamed node /a/node()/b
/a/object-node('b')/c
Final path step containing a test for an named /a/node('b')
node
Predicates, including those containing calls to /a/b[fn:matches(@attr, "is")]
safe functions or complex expressions /a/b[./c > 20]
/a/b[c < 20 and d = "dog"]/e
/a/b[c < 20][d = "dog"]/e
/a/b[fn:empty(./c)]
Forward axes a//b
/a/child::*/b
/a/descendant::b/c
Wildcards /a/*/b
/a/b/*
Namespace prefixes (assuming the namespace /ns:a/ns:b
binding is defined) /a/*:b
For more details on using namespace prefixes in indexable path expressions, see Using Namespace
Prefixes in Index Path Expressions in the Administrator’s Guide.
MarkLogic 10—May, 2019 XQuery and XSLT Reference Guide—Page 60
MarkLogic Server XPath Quick Reference
The following table contains some examples of valid XPath expressions that cannot be used to
define path-based indexes. That is, expressions that could be used in other contexts, but for which
cts:valid-index-path or cts.validIndexPath returns false.
Unsupported XPath Feature Invalid Example
Final path step containing a test for an /a/b/node()
unnamed node /a/b/element()
/a/b/boolean-node()
Reverse axes /a/b/parent::*/c
/a/b/c/ancestor::*
/a/b/../c
Calls to unsafe functions in predicates a/b[xdmp:eval(5+3)]
Complex expressions as the right operand of a /a/b[c > fn:sum((1,2,3))]
comparison operator in a predicate a/b[c > (5+3)]
5.4.2 Element Level Security
When you define a protected path for use with Element Level Security, the protected path is
restricted to the same XPath subset as is used for creating path-based indexes. For details, see
“Path Field and Path-Based Range Index Configuration” on page 59 and “Indexable Path
Expression Grammar” on page 68.
To test whether or not an XPath expression is valid as a protected path, use the XQuery function
cts:valid-index-path or the Server-Side JavaScript function cts.validIndexPath.
To learn more about element level security, see Element Level Security in the Security Guide.
5.4.3 Template Driven Extraction (TDE)
When you create a TDE template, you identify the template context using XPath expressions.
These expressions are limited to the same XPath subset as is used for creating path-based indexes,
with the following differences:
• You can use "/" as a context XPath expression if the template has collection or directory
scope. For details, see Collections and Directories in the Application Developer’s Guide.
To test an XPath expression for validity in a TDE template, use the XQuery function
cts:valid-tde-context or the Server-Side JavaScript function cts.validTdeContext.
For more details and examples, see “Path Field and Path-Based Range Index Configuration” on
page 59 and “Indexable Path Expression Grammar” on page 68.
MarkLogic 10—May, 2019 XQuery and XSLT Reference Guide—Page 61
MarkLogic Server XPath Quick Reference
To learn more about TDE, see Template Driven Extraction (TDE) in the Application Developer’s
Guide.
5.4.4 Patch Feature of the Client APIs
When you create a patch (or partial update) descriptor for use with the Java, Node.js, or REST
Client API, you identify the content to be updated using an XPath expression. These XPath
expressions are restricted to the XPath subset described here.
To test an XPath expression for validity in a patch descriptor, use the XQuery function
cts:valid-document-patch-path or the Server-Side JavaScript function
cts.validDocumentPatchPath.
The following list defines key aspects of the XPath restrictions. Additional restrictions may apply.
For a complete definition of the valid XPath subset, see “Patch and Extract Path Expression
Grammar” on page 70.
• The only operators you can use in predicate expressions are comparison and logical
operators. (=, !=, <, <=, >=, >, eq, ne, lt, le, ge, gt, and, or).
• The right operand of a comparison in a predicate can only be a string literal, numeric
literal, or a sequence of string or numeric literals.
• You can only use forward axes in path steps. That is, you can use axes such as self::,
child::, descendant::, but you cannot use reverse axes such as parent::, ancestor::, or
preceding::. For details, see http://www.w3.org/TR/xpath/#predicates.
• You can only call functions on the “safe” function list in a predicate expression. For
details, see “Functions Callable in Predicate Expressions” on page 65.
• You cannot span a fragment root. Paths must be scoped within fragment roots.
The following table provides some examples of path expressions that meet the requirements of an
indexable path expression. This set of examples is not exhaustive.
Supported XPath Feature Valid Example
Absolute path /a/b
Relative path a/b
Path step containing a test for a named or /a/node()/b
unnamed node /a/node()
/a/element(b)/c
/a/number-node()
/a/object-node('b')
MarkLogic 10—May, 2019 XQuery and XSLT Reference Guide—Page 62
MarkLogic Server XPath Quick Reference
Supported XPath Feature Valid Example
Predicates, including those containing calls to /a/b[fn:matches(@attr, "is")]
safe functions or complex expressions /a/b[./c > 20]
/a/b[c < 20 and d = "dog"]/e
/a/b[c < 20][d = "dog"]/e
/a/b[fn:empty(./c)]
Forward axes a//b
/a/child::*/b
/a/descendant::b/c
Wildcards /a/*/b
/a/b/*
Namespace prefixes (assuming the namespace /ns:a/ns:b
binding is defined) /a/*:b
The following table contains some examples of valid XPath expressions that cannot be used to
define path expressions in patch operations. That is, expressions that could be used in other
contexts, but for which cts:valid-document-patch-path or cts.validDocumentPatchPath returns
false. This set of examples is not exhaustive.
Unsupported XPath Feature Invalid Example
Reverse axes /a/b/parent::*/c
/a/b/c/ancestor::*
/a/b/../c
Calls to unsafe functions in predicates a/b[xdmp:eval(5+3)]
Complex expressions as the right operand of a /a/b[c > fn:sum((1,2,3))]
comparison operator in a predicate a/b[c > (5+3)]
To learn more about the document patch feature, see the following topics:
• Java Client API: Partially Updating Document Content and Metadata in the Java Application
Developer’s Guide
• Node.js Client API: Patching Document Content or Metadata in the Node.js Application
Developer’s Guide
• REST Client API: Partially Updating Document Content or Metadata in the REST Application
Developer’s Guide
MarkLogic 10—May, 2019 XQuery and XSLT Reference Guide—Page 63
MarkLogic Server XPath Quick Reference
5.4.5 The extract-document-data Query Option
The XQuery Search API, Server-Side JavaScript Jsearch API, and the Java, Node.js, and REST
client APIs support a query option named extract-document-data that enables you to specify
portions of a matched document to be returned in document search results. You identify the
content to be extracted by specifying an XPath expression in the extract-path portion of the
option.
The extract-path is restricted to the same XPath subset that is described in “Patch Feature of the
Client APIs” on page 62.
To test an XPath expression for validity as an extract-path value, use the XQuery function
cts:valid-extract-path or the Server-Side JavaScript function cts.validExtractPath.
To learn more about the extract-document-data query option, see extract-document-data in the
Search Developer’s Guide. To learn more about the equivalent JSearch feature, see Extracting
Portions of Each Matched Document in the Search Developer’s Guide.
The Java and Node.js Client APIs support a similar feature for Optic searches. For details, see
“The Optic API xpath Function” on page 64.
5.4.6 The Optic API xpath Function
Optic searches enable you to extract child nodes from a column with node values. You identify
these nodes with an XPath expression. This XPath expression is restricted to the subset described
in limited to the XPath subset described in “Patch Feature of the Client APIs” on page 62.
The restrictions apply to the following contexts:
• Server-Side JavaScript Optic API: op.xpath
• XQuery Optic API: op:xpath
• Node.js Client API: planBuilder.xpath
• Java Client API: com.marklogic.client.expression.PlanBuilder.xpath
To test an XPath expression for validity as an Optic xpath value, use the XQuery function
cts:valid-optic-path or the Server-Side JavaScript function cts.validOpticPath.
To learn more about the Optic API, see the following topics:
• XQuery and Server-Side JavaScript: Optic API for Multi-Model Data Access in the
Application Developer’s Guide
• Java Client API: Optic Java API for Relational Operations in the Java Application
Developer’s Guide
• Node.js Client API: Using the Optic API for Relational Operations in the Node.js Application
Developer’s Guide
MarkLogic 10—May, 2019 XQuery and XSLT Reference Guide—Page 64
MarkLogic Server XPath Quick Reference
5.4.7 Functions Callable in Predicate Expressions
In a restricted XPath subset that supports function calls in predicates, you can only call functions
known to be performant and secure in the context in which the restricted XPath applies. The
following topics list these “safe” functions:
• String Functions
• Logical and Data Validation Functions
• Date and Time Functions
• Type Casting Functions
• Mathematical Functions
• Miscellanious Functions
5.4.7.1 String Functions
Note: These functions are not supported by XQuery 0.9-ml, which has been deprecated.
fn:codepoint-equal fn:iri-to-uri fn:string-join
fn:codepoints-to-string fn:last fn:string-length
fn:compare fn:lower-case fn:string-to-codepoints
fn:concat fn:matches fn:subsequence
fn:contains fn:normalize-space fn:substring
fn:encode-for-uri fn:normalize-unicode fn:substring-after
fn:ends-with fn:position fn:substring-before
fn:escape-html-uri fn:remove fn:tokenize
fn:escape-uri fn:replace fn:translate
fn:format-number fn:reverse fn:upper-case
fn:insert-before fn:starts-with
5.4.7.2 Logical and Data Validation Functions
• fn:boolean
• fn:empty
• fn:exists
MarkLogic 10—May, 2019 XQuery and XSLT Reference Guide—Page 65
MarkLogic Server XPath Quick Reference
• fn:false
• fn:not
• fn:true
5.4.7.3 Date and Time Functions
fn:adjust-date-to-timezone fn:years-from-duration sql:seconds
fn:adjust-dateTime-to-timezone fn:day-from-date sql:timestampadd
fn:adjust-time-to-timezone fn:day-from-dateTime sql:timestampdiff
fn:month-from-date fn:days-from-duration sql:week
fn:month-from-dateTime fn:format-date sql:weekday
fn:months-from-duration fn:formate-dateTime sql:year
fn:seconds-from-dateTime fn:format-time sql:yearday
fn:seconds-from-duration fn:hours-from-dateTime sql:dateadd
fn:seconds-from-time fn:hours-from-duration sql:datediff
fn:minutes-from-dateTime fn:hours-from-time sql:datepart
fn:minutes-from-duration sql:day xdmp:dayname-from-date
fn:minutes-from-time sql:dayname xdmp:quarter-from-date
fn:timezone-from-date sql:hours xdmp:week-from-date
fn:timezone-from-dateTime sql:minutes xdmp:weekday-from-date
fn:timezone-from-time sql:month xdmp:yearday-from-date
fn:year-from-date sql:monthname xdmp:parse-yymmdd
fn:year-from-dateTime sql:quarter xdmp:parse-dateTime
5.4.7.4 Type Casting Functions
fn:number xs:float xs:gMonth
fn:string xs:double xs:gDay
xs:string xs:boolean xs:duration
MarkLogic 10—May, 2019 XQuery and XSLT Reference Guide—Page 66
MarkLogic Server XPath Quick Reference
xs:decimal xs:dateTime xs:anyURI
xs:integer xs:date xs:dayTimeDuration
xs:long xs:time xs:yearMonthDuration
xs:int xs:gYearMonth xdmp:castable-as
xs:short xs:gYear
xs:byte xs:gMonthDay
5.4.7.5 Mathematical Functions
fn:abs math:cosh math:modf
fn:ceiling math:cot math:pi
fn:floor math:degrees math:pow
fn:round math:exp math:radians
fn:round-half-to-even math:fabs math:sin
math:acos math:floor math:sinh
math:asin math:fmod math:sqrt
math:atan math:frexp math:tan
math:atan2 math:ldexp math:tanh
math:ceil math:log math:trunc
math:cos math:log10
5.4.7.6 Miscellanious Functions
fn:head fn:sum sem:invalid-datatype
fn:tail fn:count sem:typed-literal
fn:base-uri fn:avg cts:point
fn:document-uri sem:uuid xdmp:node-metadata-value
fn:lang sem:uuid-string xdmp:node-metadata
MarkLogic 10—May, 2019 XQuery and XSLT Reference Guide—Page 67
MarkLogic Server XPath Quick Reference
fn:local-name sem:bnode xdmp:node-kind
fn:name sem:datatype xdmp:node-uri
fn:namespace-uri sem:sameTerm xdmp:path
fn:node-name sem:lang xdmp:type
fn:number sem:iri
fn:root sem:unknown
fn:min sem:unknown-datatype
fn:max sem:invalid
5.4.8 Indexable Path Expression Grammar
Most users can rely on the examples in “Path Field and Path-Based Range Index Configuration”
on page 59 and the validity checking function appropriate to the context to develop valid path
range index expressions. For example, use cts:valid-index-path or cts.validIndexPath to test a
path expression.
For advanced users, this section contains a detailed grammar that defines the subset of XPath you
can use to define path-based indexes. The same grammar applies to XPath expressions for the
following features. Any differences are called out below.
• Template Driven Extraction (TDE): TDE also allows the use of “/” as a TDE context XPath
expression in some cases.
• Element Level Security: No differences.
The grammar is derived from the W3C XML Path Language specification; for details, see
http://www.w3.org/TR/xpath/. If you find it easier to explore the grammar graphically, the BNF is
suitable for use with many tools that generate “railroad diagrams” from BNF, such as
http://bottlecaps.de/rr/ui.
The following grammar expresses the XPath subset you can use to define path-based indexes.
Note that FunctionalCall in the grammar can only be a call to one of the functions listed in
“Functions Callable in Predicate Expressions” on page 65. Also, an unamed KindTest cannot be
used as the leaf step.
IndexablePathExpr ::= (PathExpr)* (("/" | "//") LeafExpr Predicates)
LeafExpr ::= "(" UnionExpr ")" | LeafStep
PathExpr ::= ("/" RelativePathExpr?)
| ("//" RelativePathExpr)
| RelativePathExpr
RelativePathExpr ::= UnionExpr | "(" UnionExpr ")"
UnionExpr ::= GeneralStepExpr ("|" GeneralStepExpr)*
GeneralStepExpr ::= ("/" | "//")? StepExpr (("/" | "//")? StepExpr)*
MarkLogic 10—May, 2019 XQuery and XSLT Reference Guide—Page 68
MarkLogic Server XPath Quick Reference
StepExpr ::= ForwardStep Predicates
ForwardStep ::= (ForwardAxis AbbreviatedFwdStep)
| AbbreviatedFwdStep
AbbreviatedFwdStep ::= "." | ("@" NameTest) | NameTest | KindTest
LeafStep ::= ("@"QName) | QName | NamedKindTest
NameTest ::= QName | Wildcard
Wildcard ::= "*" | NCName ":" "*" | "*" ":" NCName
QName ::= PrefixedName | UnprefixedName
PrefixedName ::= Prefix ":" LocalPart
UnprefixedName ::= LocalPart
Prefix ::= NCName
LocalPart ::= NCName
NCName ::= Name - (Char* ":" Char*) /* An XML Name, minus the ":"
*/
Name ::= NameStartChar (NameChar)*
QuotedNCName ::= "'" NCName "'"
| '"' NCName '"'
Predicates ::= Predicate*
Predicate ::= PredicateExpr | "[" Digit+ "]"
Digit ::= [0-9]
PredicateExpr ::= "[" PredicateExpr "and" PredicateExpr "]"
| "[" PredicateExpr "or" PredicateExpr "]"
| "[" ComparisonExpr "]" | "[" FunctionExpr "]"
ComparisonExpr ::= RelativePathExpr GeneralComp SequenceExpr
| RelativePathExpr ValueComp Literal
| PathExpr
FunctionExpr ::= FunctionCall GeneralComp SequenceExpr
| FunctionCall ValueComp Literal
| FunctionCall
GeneralComp ::= "=" | "!=" | "<" | "<=" | ">" | ">="
ValueComp ::= "eq" | "ne" | "lt" | "le" | "gt" | "ge"
SequenceExpr ::= Literal+
Literal ::= NumericLiteral | StringLiteral
KindTest ::= "attribute" "(" QNameOrWildcard? ")"
| "element" "(" QNameOrWildcard? ")"
| "array-node" "(" QuotedNCName? ")"
| "object-node" "(" QuotedNCName? ")"
| "boolean-node" "(" QuotedNCName? ")"
| "number-node" "(" QuotedNCName? ")"
| "null-node" "(" QuotedNCName? ")"
| "node" "(" QuotedNCName? ")"
| "schema-element" "(" QName ")"
| "schema-attribute" "(" QName ")"
| "processing-instruction" "(" (NCName |
StringLiteral)? ")"
NamedKindTest ::= "attribute" "(" QNameOrWildcard ")"
| "element" "(" QNameOrWildcard ")"
| "array-node" "(" QuotedNCName ")"
| "object-node" "(" QuotedNCName ")"
| "boolean-node" "(" QuotedNCName ")"
| "number-node" "(" QuotedNCName ")"
| "null-node" "(" QuotedNCName ")"
MarkLogic 10—May, 2019 XQuery and XSLT Reference Guide—Page 69
MarkLogic Server XPath Quick Reference
| "node" "(" QuotedNCName ")"
| "schema-element" "(" QName ")"
| "schema-attribute" "(" QName ")"
| "processing-instruction" "(" (NCName |
StringLiteral) ")"
QNameOrWildcard ::= QName | "*"
5.4.9 Patch and Extract Path Expression Grammar
Most users can rely on the summary and examples in “Patch Feature of the Client APIs” on
page 62 and the validity checking function appropriate to the context to develop valid path
expressions. For example, use cts:valid-document-patch-path or cts.documentPatchPath to test
a path expression.
For advanced users, this section contains a detailed grammar that defines the subset of XPath you
can use with the following features. More details and examples are available in the referenced
topics.
• Patch Feature of the Client APIs
• The extract-document-data Query Option
• The Optic API xpath Function
The grammar is derived from the W3C XML Path Language specification; for details, see
http://www.w3.org/TR/xpath/. If you find it easier to explore the grammar graphically, the BNF is
suitable for use with many tools that generate “railroad diagrams” from BNF, such as
http://bottlecaps.de/rr/ui.
The following grammar expresses the XPath subset. Note that FunctionalCall in the grammar can
only be a call to one of the functions listed in “Functions Callable in Predicate Expressions” on
page 65.
ExtractPathExpr ::= ("/" RelativePathExpr?)
| ("//" RelativePathExpr)
| RelativePathExpr
RelativePathExpr ::= UnionExpr | "(" UnionExpr ")"
UnionExpr ::= GeneralStepExpr ("|" GeneralStepExpr)*
GeneralStepExpr ::= ("/" | "//")? StepExpr (("/" | "//")? StepExpr)*
StepExpr ::= ForwardStep Predicates
ForwardStep ::= (ForwardAxis AbbreviatedFwdStep)
| AbbreviatedFwdStep
AbbreviatedFwdStep ::= "." | ("@" NameTest) | NameTest | KindTest
NameTest ::= QName | Wildcard
Wildcard ::= "*" | NCName ":" "*" | "*" ":" NCName
QName ::= PrefixedName | UnprefixedName
PrefixedName ::= Prefix ":" LocalPart
UnprefixedName ::= LocalPart
Prefix ::= NCName
LocalPart ::= NCName
NCName ::= Name - (Char* ":" Char*) /* An XML Name, minus
MarkLogic 10—May, 2019 XQuery and XSLT Reference Guide—Page 70