Skip to content

Latest commit

 

History

History
39 lines (29 loc) · 1.7 KB

File metadata and controls

39 lines (29 loc) · 1.7 KB
title Data Accessor Functions | Microsoft Docs
ms.custom
ms.date 03/14/2017
ms.prod sql
ms.prod_service sql
ms.reviewer
ms.technology xml
ms.topic language-reference
dev_langs
XML
helpviewer_keywords
data-accessor functions [XQuery]
ms.assetid 31bad04f-7c74-4773-9f83-612704fdd21c
author rothja
ms.author jroth

Data Accessor Functions

[!INCLUDEtsql-appliesto-ss2012-xxxx-xxxx-xxx-md]

The topics in this section discuss and provide sample code for the data-accessor functions.

Understanding fn:data(), fn:string(), and text()

XQuery has a function fn:data() to extract scalar, typed values from nodes, a node test text() to return text nodes, and the function fn:string() that returns the string value of a node. Their use can be confusing. The following are guidelines for using them correctly in [!INCLUDEssNoVersion]. The XML instance <age>12</age> is used for the purpose of illustration.

  • Untyped XML: The path expression /age/text() returns the text node "12". The function fn:data(/age) returns the string value "12" and so does fn:string(/age).

  • Typed XML: The expression /age/text() returns a static error for any simple typed <age> element. On the other hand, fn:data(/age) returns integer 12. The fn:string(/age) yields the string "12".

In This Section

See Also

Path Expressions (XQuery)