Bagikan melalui


ANTARA (T-SQL)

Berlaku untuk: Titik akhir analitik SQL Server Azure SQL Database Azure SQL Managed Instance Azure Synapse Analytics Platform System (PDW) SQL di Microsoft Fabric Warehouse di Microsoft Fabric

Menentukan rentang yang akan diuji.

Konvensi sintaks transact-SQL

Sintaks

test_expression [ NOT ] BETWEEN begin_expression AND end_expression  

Argumen

test_expression
Adalah ekspresi yang akan diuji dalam rentang yang ditentukan oleh begin_expressiondan end_expression. test_expression harus tipe data yang sama dengan begin_expression dan end_expression.

TIDAK
Menentukan bahwa hasil predikat dinegasikan.

begin_expression
Adalah ekspresi yang valid. begin_expression harus tipe data yang sama dengan test_expression dan end_expression.

end_expression
Adalah ekspresi yang valid. end_expression harus tipe data yang sama dengan test_expressiondan begin_expression.

AND
Bertindak sebagai tempat penampung yang menunjukkan test_expression harus berada dalam rentang yang ditunjukkan oleh begin_expression dan end_expression.

Jenis Hasil

Boolean

Nilai Hasil

BETWEEN mengembalikan TRUE jika nilai test_expression lebih besar dari atau sama dengan nilai begin_expression dan kurang dari atau sama dengan nilai end_expression.

NOT BETWEEN mengembalikan TRUE jika nilai test_expression kurang dari nilai begin_expression atau lebih besar dari nilai end_expression.

Keterangan

Untuk menentukan rentang eksklusif, gunakan yang lebih besar dari (>) dan kurang dari operator (<). Jika ada input ke predikat ANTARA atau NOT BETWEEN adalah NULL, hasilnya TIDAK DIKETAHUI.

Contoh

J. Menggunakan BETWEEN

Contoh berikut mengembalikan informasi tentang peran database dalam database. Kueri pertama mengembalikan semua peran. Contoh kedua menggunakan klausul BETWEEN untuk membatasi peran ke nilai yang ditentukan database_id .

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  

Berikut set hasilnya.

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. Menggunakan > dan < alih-alih BETWEEN

Contoh berikut menggunakan operator yang lebih besar dari (>) dan kurang dari (<) dan, karena operator ini tidak inklusif, mengembalikan sembilan baris alih-alih sepuluh yang dikembalikan dalam contoh sebelumnya.

-- 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  

Berikut set hasilnya.

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. Menggunakan NOT BETWEEN

Contoh berikut menemukan semua baris di luar rentang tertentu melalui 27 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. Menggunakan BETWEEN dengan nilai tanggalwaktu

Contoh berikut mengambil baris di mana nilai tanggalwaktu berada di antara '20011212' dan '20020105', inklusif.

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

Berikut set hasilnya.

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

Kueri mengambil baris yang diharapkan karena nilai tanggal dalam kueri dan nilai tanggalwaktu yang disimpan dalam RateChangeDate kolom telah ditentukan tanpa bagian waktu dari tanggal. Ketika bagian waktu tidak ditentukan, itu default ke 12:00 A.M. Perhatikan bahwa baris yang berisi bagian waktu setelah 12:00 A.M. pada 2002-01-05 tidak akan dikembalikan oleh kueri ini karena berada di luar rentang.

Lihat Juga

> (Lebih Besar Dari) (T-SQL)
< (Kurang Dari) (T-SQL)
Ekspresi (Transact-SQL)
Fungsi Bawaan (Transact-SQL)
Operator (Transact-SQL)
SELECT (Transact-SQL)
WHERE (Transact-SQL)