Compartir vía


Expresiones condicionales (XQuery)

Se aplica a: SQL Server

XQuery admite la siguiente instrucción if-then-else condicional:

if (<expression1>)  
then  
  <expression2>  
else  
  <expression3>  

Según el valor booleano efectivo de expression1, se evalúa expression2 o expression3. Por ejemplo:

  • Si la expresión de prueba expression1 da como resultado una secuencia vacía, el resultado será False.

  • Si la expresión de prueba expression1 da como resultado un valor booleano simple, este valor será el resultado de la expresión.

  • Si la expresión de prueba expression1 da como resultado una secuencia de uno o varios nodos, el resultado de la expresión será True.

  • De lo contrario, se generará un error estático.

También tenga en cuenta lo siguiente:

  • La expresión de prueba se debe escribir entre paréntesis.

  • Se requiere la expresión else . Si no la necesita, puede devolver " ( ) ", tal como se ilustra en los ejemplos de este tema.

Por ejemplo, la consulta siguiente se especifica en la variable de tipo xml . La condición if comprueba el valor de la variable SQL (@v) dentro de la expresión XQuery mediante la función de extensión de función sql:variable(). Si el valor de la variable es "FirstName", devuelve el <FirstName> elemento . De lo contrario, devuelve el <LastName> elemento .

declare @x xml  
declare @v varchar(20)  
set @v='FirstName'  
set @x='  
<ROOT rootID="2">  
  <FirstName>fname</FirstName>  
  <LastName>lname</LastName>  
</ROOT>'  
SELECT @x.query('  
if ( sql:variable("@v")="FirstName" ) then  
  /ROOT/FirstName  
 else  
   /ROOT/LastName  
')  

El resultado es el siguiente:

<FirstName>fname</FirstName>  

La consulta siguiente recupera las dos primeras descripciones de características de la descripción del catálogo de productos de un modelo de producto determinado. Si hay más características en el documento, agrega un <there-is-more> elemento con contenido vacío.

SELECT CatalogDescription.query('  
     declare namespace p1="https://schemas.microsoft.com/sqlserver/2004/07/adventure-works/ProductModelDescription";  
     <Product>   
          { /p1:ProductDescription/@ProductModelID }  
          { /p1:ProductDescription/@ProductModelName }   
          {  
            for $f in /p1:ProductDescription/p1:Features/*[position()\<=2]  
            return  
            $f   
          }  
          {  
            if (count(/p1:ProductDescription/p1:Features/*) > 2)  
            then \<there-is-more/>  
            else ()  
          }   
     </Product>          
') as x  
FROM Production.ProductModel  
WHERE ProductModelID = 19  

En la consulta anterior, la condición de la expresión if comprueba si hay más de dos elementos secundarios enFeatures<> . Si éste es el caso, devuelve el elemento \<there-is-more/> en el resultado.

El resultado es el siguiente:

<Product ProductModelID="19" ProductModelName="Mountain 100">  
  \<p1:Warranty xmlns:p1="https://schemas.microsoft.com/sqlserver/2004/07/adventure-works/ProductModelWarrAndMain">  
    \<p1:WarrantyPeriod>3 years\</p1:WarrantyPeriod>  
    \<p1:Description>parts and labor\</p1:Description>  
  \</p1:Warranty>  
  \<p2:Maintenance xmlns:p2="https://schemas.microsoft.com/sqlserver/2004/07/adventure-works/ProductModelWarrAndMain">  
    \<p2:NoOfYears>10 years\</p2:NoOfYears>  
    \<p2:Description>maintenance contract available through your dealer or any AdventureWorks retail store.\</p2:Description>  
  \</p2:Maintenance>  
  \<there-is-more />  
</Product>  

En la consulta siguiente, se devuelve un <Location> elemento con un atributo LocationID si la ubicación del centro de trabajo no especifica las horas de instalación.

SELECT Instructions.query('  
     declare namespace AWMI="https://schemas.microsoft.com/sqlserver/2004/07/adventure-works/ProductModelManuInstructions";  
        for $WC in //AWMI:root/AWMI:Location  
        return  
        if ( $WC[not(@SetupHours)] )  
        then  
          <WorkCenterLocation>  
             { $WC/@LocationID }   
          </WorkCenterLocation>  
         else  
           ()  
') as Result  
FROM Production.ProductModel  
where ProductModelID=7  

El resultado es el siguiente:

<WorkCenterLocation LocationID="30" />  
<WorkCenterLocation LocationID="45" />  
<WorkCenterLocation LocationID="60" />  

Esta consulta se puede escribir sin la cláusula if , como se muestra en el ejemplo siguiente:

SELECT Instructions.query('  
     declare namespace AWMI="https://schemas.microsoft.com/sqlserver/2004/07/adventure-works/ProductModelManuInstructions";  
for $WC in //AWMI:root/AWMI:Location[not(@SetupHours)]   
        return  
          <Location>  
             { $WC/@LocationID }   
          </Location>  
') as Result  
FROM Production.ProductModel  
where ProductModelID=7  

Consulte también

Expresiones XQuery