Функции-конструкторы (XQuery)
Область применения: SQL Server
Функции-конструкторы по указанным входным данным создают экземпляры любых встроенных атомарных типов XSD или пользовательских атомарных типов.
Синтаксис
TYP($atomicvalue as xdt:anyAtomicType?
) as TYP?
Аргументы
$strval
Строка, которая будет преобразована.
ТИП
Любой встроенный тип XSD.
Замечания
Конструкторы поддерживаются и базовыми, и производными атомарными типами XSD. Однако подтипы xs:duration, которые включают xdt:yearMonthDuration и xdt:dayTimeDuration, а xs:QName, xs:NMTOKEN и xs:NOTATION не поддерживаются. Пользовательские атомарные типы, доступные в ассоциированных коллекциях схем, также доступны, если они прямо или косвенно произведены от следующих типов.
Поддерживаемые базовые типы
Функции-конструкторы поддерживаются следующими базовыми типами:
xs:string
xs:boolean
xs:decimal
xs:float
xs:double
xs:duration
xs:dateTime
xs:time
xs:date
xs:gYearMonth
xs:gYear
xs:gMonthDay
xs:gDay
xs:gMonth
xs:hexBinary
xs:base64Binary
xs:anyURI
Поддерживаемые производные типы
Функции-конструкторы поддерживаются следующими производными типами:
xs:normalizedString
xs:token
xs:language
xs:Name
xs:NCName
xs:ID
xs:IDREF
xs:ENTITY
xs:integer
xs:nonPositiveInteger
xs:negativeInteger
xs:long
xs:int
xs:short
xs:byte
xs:nonNegativeInteger
xs:unsignedLong
xs:unsignedInt
xs:unsignedShort
xs:unsignedByte
xs:positiveInteger
Кроме того, SQL Server поддерживает свертывание констант при вызове функций-конструкторов:
Если аргумент является строковым литералом, выражение оценивается во время компиляции. Если значение не соответствует ограничениям типа, возвращается статическая ошибка.
Если аргумент является литералом другого типа, выражение оценивается во время компиляции. Если значение не соответствует ограничениям типа, возвращается пустая последовательность.
Примеры
В этом разделе приведены примеры XQuery для экземпляров XML, хранящихся в различных столбцах типа XML в базе данных AdventureWorks.
А. Использование функции dateTime() языка XQuery для получения описаний старой продукции
В этом примере пример XML-документа сначала назначается переменной типа XML . Этот документ содержит три примера <ProductDescription
> элементов, каждый из которых содержит дочерний <DateCreated
> элемент.
После этого выполняется запрос переменной, получающей описания только тех продуктов, которые были произведены до указанной даты. Для сравнения запрос использует функцию конструктора xs:dateTime() для ввода дат.
declare @x xml
set @x = '<root>
<ProductDescription ProductID="1" >
<DateCreated DateValue="2000-01-01T00:00:00Z" />
<Summary>Some Summary description</Summary>
</ProductDescription>
<ProductDescription ProductID="2" >
<DateCreated DateValue="2001-01-01T00:00:00Z" />
<Summary>Some Summary description</Summary>
</ProductDescription>
<ProductDescription ProductID="3" >
<DateCreated DateValue="2002-01-01T00:00:00Z" />
<Summary>Some Summary description</Summary>
</ProductDescription>
</root>'
select @x.query('
for $PD in /root/ProductDescription
where xs:dateTime(data( ($PD/DateCreated/@DateValue)[1] )) < xs:dateTime("2001-01-01T00:00:00Z")
return
element Product
{
( attribute ProductID { data($PD/@ProductID ) },
attribute DateCreated { data( ($PD/DateCreated/@DateValue)[1] ) } )
}
')
Обратите внимание на следующие данные из предыдущего запроса:
FOR ... Структура цикла WHERE используется для получения <элемента ProductDescription> , удовлетворяющего условию, указанному в предложении WHERE.
Функция конструктора dateTime() используется для создания значений типов dateTime, чтобы их можно было сравнить соответствующим образом.
После этого запрос создает итоговый XML-код. Так как при этом создается последовательность атрибутов, при формировании XML-кода используются запятые и скобки.
Результат:
<Product
ProductID="1"
DateCreated="2000-01-01T00:00:00Z"/>
См. также
Конструкторы XML (XQuery)
Функции XQuery для типа данных XML