Rumah > pangkalan data > tutorial mysql > Adakah Pengendali `ANTARA` MS SQL Server Termasuk Nilai Sempadan?

Adakah Pengendali `ANTARA` MS SQL Server Termasuk Nilai Sempadan?

Patricia Arquette
Lepaskan: 2025-01-01 03:50:10
asal
734 orang telah melayarinya

Does MS SQL Server's `BETWEEN` Operator Include the Boundary Values?

Sifat Inklusif Pengendali "ANTARA" MS SQL Server

Adakah pengendali BETWEEN MS SQL Server termasuk sempadan julat? Dalam erti kata lain, adakah pertanyaan berikut:

SELECT foo
FROM bar
WHERE foo BETWEEN 5 AND 10
Salin selepas log masuk

memilih nilai yang betul-betul 5 dan 10, atau adakah nilai ini dikecualikan daripada julat?

Jawapan:

Pengendali BETWEEN dalam MS SQL Server adalah inklusif, yang bermaksud bahawa ia termasuk kedua-dua nilai permulaan dan akhir dalam julat yang ditentukan. Oleh itu, pertanyaan di atas akan memilih baris di mana lajur foo mempunyai nilai antara dan termasuk 5 dan 10.

Dari Buku Dalam Talian:

ANTARA mengembalikan BENAR jika nilai uji_ungkapan adalah lebih besar daripada atau sama dengan nilai permulaan_ungkapan dan kurang daripada atau sama dengan nilai end_expression.

Kaveat TarikhMasa:

Apabila bekerja dengan DateTimes, adalah penting untuk ambil perhatian bahawa jika hanya tarikh diberikan, nilai itu dianggap sebagai tengah malam pada hari tersebut. Untuk mengelakkan masa hilang dalam tarikh tamat atau menduplikasi penangkapan data untuk data hari berikutnya, anda disyorkan untuk menolak 3 milisaat daripada tarikh tamat. Ini kerana sebarang nilai yang kurang daripada 3 milisaat akan dibundarkan kepada tengah malam pada hari berikutnya.

Contoh:

Untuk mendapatkan semua nilai dalam bulan Jun 2016, gunakan yang berikut pertanyaan:

where myDateTime between '20160601' and DATEADD(millisecond, -3, '20160701')
Salin selepas log masuk

Ini diterjemahkan kepada:

where myDateTime between '20160601 00:00:00.000' and '20160630 23:59:59.997'
Salin selepas log masuk

datetime2 dan datetimeoffset:

Menolak 3 ms daripada tarikh boleh menyebabkan baris hilang dalam tetingkap 3 ms. Penyelesaian yang paling berkesan ialah menggunakan operator berikut:

where myDateTime >= '20160601' AND myDateTime < '20160701'
Salin selepas log masuk

Atas ialah kandungan terperinci Adakah Pengendali `ANTARA` MS SQL Server Termasuk Nilai Sempadan?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan