Logical Expressions (XQuery)
Applies To: SQL Server 2014, SQL Server 2016 Preview
Topic Status: Some information in this topic is preview and subject to change in future releases. Preview information describes new features or changes to existing features in Microsoft SQL Server 2016 Community Technology Preview 2 (CTP2).
XQuery supports the logical and and or operators.
expression1 and expression2 expression1 or expression2
The test expressions, expression1, expression2, in SQL Server can result in an empty sequence, a sequence of one or more nodes, or a single Boolean value. Based on the result, their effective Boolean value is determined in the following manner:
If the test expression results in an empty sequence, the result of the expression is False.
If the test expression results in a single Boolean value, this value is the result of the expression.
If the test expression results in a sequence of one or more nodes, the result of the expression is True.
Otherwise, a static error is raised.
The logical and and or operator is then applied to the resulting Boolean values of the expressions with the standard logical semantics.
The following query retrieves from the product catalog the front-angle small pictures, the <Picture> element, for a specific product model. Note that for each product description document, the catalog can store one or more product pictures with different attributes, such as size and angle.
SELECT CatalogDescription.query(' declare namespace PD="http://schemas.microsoft.com/sqlserver/2004/07/adventure-works/ProductModelDescription"; for $F in /PD:ProductDescription/PD:Picture[PD:Size="small" and PD:Angle="front"] return $F ') as Result FROM Production.ProductModel where ProductModelID=19
This is the result:
<PD:Picture xmlns:PD="http://schemas.microsoft.com/sqlserver/2004/07/adventure-works/ProductModelDescription"> <PD:Angle>front</PD:Angle> <PD:Size>small</PD:Size> <PD:ProductPhotoID>31</PD:ProductPhotoID> </PD:Picture>