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
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')
Ini diterjemahkan kepada:
where myDateTime between '20160601 00:00:00.000' and '20160630 23:59:59.997'
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'
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!