BETWEEN (Transact-SQL)BETWEEN (Transact-SQL)

ESTE TEMA SE APLICA A: síSQL Server (a partir de 2008)síAzure SQL DatabasesíAzure SQL Data Warehouse síAlmacenamiento de datos paralelos THIS TOPIC APPLIES TO: yesSQL Server (starting with 2008)yesAzure SQL DatabaseyesAzure SQL Data Warehouse yesParallel Data Warehouse

Especifica un intervalo que se va a probar.Specifies a range to test.

Icono de vínculo de tema Convenciones de sintaxis de Transact-SQLTopic link icon Transact-SQL Syntax Conventions

SintaxisSyntax

test_expression [ NOT ] BETWEEN begin_expression AND end_expression  

ArgumentosArguments

test_expressiontest_expression
Es el expresión para la prueba en el intervalo definido por begin_expressiony end_expression.Is the expression to test for in the range defined by begin_expressionand end_expression. test_expression debe ser el mismo tipo de datos que begin_expression y end_expression.test_expression must be the same data type as both begin_expression and end_expression.

NOTNOT
Especifica que se niega el resultado del predicado.Specifies that the result of the predicate be negated.

begin_expressionbegin_expression
Es cualquier expresión válida.Is any valid expression. begin_expression debe ser el mismo tipo de datos que test_expression y end_expression.begin_expression must be the same data type as both test_expression and end_expression.

end_expressionend_expression
Es cualquier expresión válida.Is any valid expression. end_expression debe ser el mismo tipo de datos que test_expressiony begin_expression.end_expression must be the same data type as both test_expressionand begin_expression.

yAND
Actúa como un marcador de posición que indica test_expression debe estar dentro del intervalo indicado por begin_expression y end_expression.Acts as a placeholder that indicates test_expression should be within the range indicated by begin_expression and end_expression.

Tipos de resultadoResult Types

BooleanBoolean

Valor de resultadoResult Value

BETWEEN devuelve TRUE si el valor de test_expression es mayor o igual que el valor de begin_expression y menor o igual que el valor de end_expression.BETWEEN returns TRUE if the value of test_expression is greater than or equal to the value of begin_expression and less than or equal to the value of end_expression.

NOT BETWEEN devuelve TRUE si el valor de test_expression es menor que el valor de begin_expression o mayor que el valor de end_expression .NOT BETWEEN returns TRUE if the value of test_expression is less than the value of begin_expression or greater than the value of end_expression.

ComentariosRemarks

Para especificar un intervalo exclusivo, utilice los operadores mayor que (>) y menor que (<).To specify an exclusive range, use the greater than (>) and less than operators (<). Si alguna entrada del predicado BETWEEN o NOT BETWEEN es NULL, el resultado es UNKNOWN.If any input to the BETWEEN or NOT BETWEEN predicate is NULL, the result is UNKNOWN.

EjemplosExamples

A.A. Utilizar BETWEENUsing BETWEEN

En el ejemplo siguiente se devuelve información acerca de los roles de base de datos en una base de datos.The following example returns information about the database roles in a database. La primera consulta devuelve todos los roles.The first query returns all the roles. El segundo ejemplo se usa el BETWEEN cláusula para limitar los roles a los especificados database_id valores.The second example uses the BETWEEN clause to limit the roles to the specified database_id values.

SELECT principal_id, name 
FROM sys.database_principals
WHERE type = 'R';

SELECT principal_id, name 
FROM sys.database_principals
WHERE type = 'R'
AND principal_id BETWEEN 16385 AND 16390;
GO  

El conjunto de resultados es el siguiente.Here is the result set.

principal_id    name
------------  ---- 
0               public
16384           db_owner
16385           db_accessadmin
16386           db_securityadmin
16387           db_ddladmin
16389           db_backupoperator
16390           db_datareader
16391           db_datawriter
16392           db_denydatareader
16393           db_denydatawriter
principal_id    name
------------  ---- 
16385           db_accessadmin
16386           db_securityadmin
16387           db_ddladmin
16389           db_backupoperator
16390           db_datareader

B.B. Utilizar > y < en lugar de BETWEENUsing > and < instead of BETWEEN

En el siguiente ejemplo se utilizan los operadores mayor que (>) y menor que (<) y, puesto que dichos operadores no son inclusivos, se devuelven nueve filas en lugar de las diez devueltas en el ejemplo anterior.The following example uses greater than (>) and less than (<) operators and, because these operators are not inclusive, returns nine rows instead of ten that were returned in the previous example.

-- Uses AdventureWorks  

SELECT e.FirstName, e.LastName, ep.Rate  
FROM HumanResources.vEmployee e   
JOIN HumanResources.EmployeePayHistory ep   
    ON e.BusinessEntityID = ep.BusinessEntityID  
WHERE ep.Rate > 27 AND ep.Rate < 30  
ORDER BY ep.Rate;  
GO  

El conjunto de resultados es el siguiente.Here is the result set.

FirstName   LastName             Rate  
---------   -------------------  ---------  
Paula       Barreto de Mattos    27.1394  
Janaina     Bueno                27.4038  
Dan         Bacon                27.4038  
Ramesh      Meyyappan            27.4038  
Karen       Berg                 27.4038  
David       Bradley              28.7500  
Hazem       Abolrous             28.8462  
Ovidiu      Cracium              28.8462  
Rob         Walters              29.8462  

C.C. Utilizar NOT BETWEENUsing NOT BETWEEN

En el siguiente ejemplo se buscan todas las filas que no están incluidas en un intervalo especificado de 27 a 30.The following example finds all rows outside a specified range of 27 through 30.

-- Uses AdventureWorks  

SELECT e.FirstName, e.LastName, ep.Rate  
FROM HumanResources.vEmployee e   
JOIN HumanResources.EmployeePayHistory ep   
    ON e.BusinessEntityID = ep.BusinessEntityID  
WHERE ep.Rate NOT BETWEEN 27 AND 30  
ORDER BY ep.Rate;  
GO  

D.D. Utilizar BETWEEN con valores datetimeUsing BETWEEN with datetime values

En el ejemplo siguiente se recuperan filas en las que datetime valores están comprendidos entre '20011212' y '20020105', ambos inclusive.The following example retrieves rows in which datetime values are between '20011212' and '20020105', inclusive.

-- Uses AdventureWorks  

SELECT BusinessEntityID, RateChangeDate  
FROM HumanResources.EmployeePayHistory  
WHERE RateChangeDate BETWEEN '20011212' AND '20020105';  

El conjunto de resultados es el siguiente.Here is the result set.

BusinessEntityID RateChangeDate  
----------- -----------------------  
3           2001-12-12 00:00:00.000  
4           2002-01-05 00:00:00.000  

La consulta recupera las filas previstas porque los valores de fecha en la consulta y la datetime valores almacenados en la RateChangeDate columna se han especificado sin la parte de hora de la fecha.The query retrieves the expected rows because the date values in the query and the datetime values stored in the RateChangeDate column have been specified without the time part of the date. Si no se especifica la parte de hora, toma el valor predeterminado 12:00 a.m.When the time part is unspecified, it defaults to 12:00 A.M. Tenga en cuenta que esta consulta no devolverá una fila que contenga una parte de hora posterior a 12:00 a.m.Note that a row that contains a time part that is after 12:00 A.M. del 05-01-2002, ya que está fuera del rango.on 2002-01-05 would not be returned by this query because it falls outside the range.

Vea tambiénSee Also

> ( Mayor ) ( Transact-SQL ) > (Greater Than) (Transact-SQL)
< ( Menor ) ( Transact-SQL ) < (Less Than) (Transact-SQL)
Expresiones ( Transact-SQL ) Expressions (Transact-SQL)
Funciones integradas (Transact-SQL) Built-in Functions (Transact-SQL)
Operadores ( Transact-SQL ) Operators (Transact-SQL)
SELECT (Transact-SQL) SELECT (Transact-SQL)
DONDE ( Transact-SQL )WHERE (Transact-SQL)