Bagikan melalui


ANTARA (Transact-SQL)

Berlaku untuk:SQL ServerAzure SQL DatabaseAzure SQL Managed InstanceAzure Synapse AnalyticsSistem Platform Analitik (PDW)Titik akhir analitik SQL di Microsoft FabricGudang di Microsoft FabricDatabase SQL di Microsoft Fabric

Menentukan rentang yang akan diuji.

Konvensi sintaks transact-SQL

Syntax

test_expression [ NOT ] BETWEEN begin_expression AND end_expression

Arguments

test_expression

Ekspresi untuk diuji dalam rentang yang ditentukan oleh begin_expressiondan end_expression. test_expression harus tipe data yang sama dengan begin_expression dan end_expression.

NOT

Menentukan bahwa hasil predikat dinegasikan.

begin_expression

Ekspresi apa pun yang valid. begin_expression harus tipe data yang sama dengan test_expression dan end_expression.

end_expression

Ekspresi apa pun 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.

Tipe pengembalian

Boolean

Remarks

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.

Untuk menentukan rentang eksklusif, gunakan yang lebih besar dari (>) dan kurang dari operator (<). Jika ada input ke predikat BETWEEN atau NOT BETWEENNULL, hasilnya tergantung pada hasil bagian konstituen.

Dalam contoh berikut test_expression >= begin_expression AND test_expression <= end_expression, jika salah satu bagian FALSE maka ekspresi BETWEEN keseluruhan mengevaluasi ke FALSE. Jika tidak, ekspresi mengevaluasi ke UNKNOWN.

Examples

Sampel kode dalam artikel ini menggunakan database sampel AdventureWorks2025 atau AdventureWorksDW2025, yang dapat Anda unduh dari halaman beranda Sampel dan Proyek Komunitas Microsoft SQL Server.

A. Gunakan ANTARA

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

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
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
------------  ----
16385         db_accessadmin
16386         db_securityadmin
16387         db_ddladmin
16389         db_backupoperator
16390         db_datareader

B. Gunakan > 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 10 yang dikembalikan dalam contoh sebelumnya.

SELECT e.FirstName,
       e.LastName,
       ep.Rate
FROM HumanResources.vEmployee AS e
     INNER JOIN HumanResources.EmployeePayHistory AS 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. Gunakan NOT BETWEEN

Contoh berikut menemukan semua baris di luar rentang tertentu melalui 2730.

SELECT e.FirstName,
       e.LastName,
       ep.Rate
FROM HumanResources.vEmployee AS e
     INNER JOIN HumanResources.EmployeePayHistory AS 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.

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 tanggalwaktu nilai yang disimpan dalam kolom RateChangeDate ditentukan tanpa bagian waktu dari tanggal. Ketika bagian waktu tidak ditentukan, itu default ke 12:00 A.M. Baris yang berisi bagian waktu setelah pukul 12:00 A.M. pada 5 Januari 2002, tidak dikembalikan oleh kueri ini, karena berada di luar rentang.