Mencari Julat Tarikh Bertindih dalam PostgreSQL
Tugas yang ada ialah untuk mendapatkan semula senarai pemain yang dikaitkan dengan pasukan tertentu dalam masa yang ditetapkan bingkai. Walaupun pertanyaan yang diberikan cuba mencapai matlamat ini, ia gagal disebabkan oleh logik yang salah dan salah faham asas tentang cara mengenal pasti julat bertindih.
Untuk mencipta pertanyaan yang mengenal pasti pemain dengan tepat dalam jangka masa yang dikehendaki, beberapa prinsip utama mesti dipertimbangkan:
-
Perbandingan Julat Tarikh yang Betul: ANTARA pengendali, seperti yang digunakan dalam pertanyaan asal, termasuk sempadan atas. Ini tidak betul apabila berurusan dengan julat bertindih, yang sepatutnya eksklusif. Sebaliknya, perbandingan yang sesuai ialah < atau = antara sempadan bawah dan sempadan atas, memastikan bahawa hanya tarikh dalam julat yang ditentukan ditangkap.
-
Pertimbangan Nilai NULL: Bagi pemain yang masih belum meninggalkan pasukan, lajur date_leave mungkin NULL. Pertanyaan mesti mengambil kira kemungkinan ini dengan membenarkan nilai NULL disertakan dalam perbandingan julat bertindih.
-
Mengendalikan Potensi Pendua: Apabila berbilang kontrak wujud untuk pemain yang sama, adalah penting untuk disatukan keputusan untuk menghapuskan pendua. Kata kunci DISTINCT boleh digunakan untuk memastikan bahawa hanya nama pemain unik dikembalikan.
-
SQL OVERLAPS Operator: PostgreSQL menawarkan operator OVERLAPS terbina dalam, yang direka khusus untuk menentukan sama ada dua kali tempoh bersilang. Operator ini boleh memudahkan pertanyaan dengan menghapuskan keperluan untuk perbandingan tarikh yang jelas.
-
Jenis Julat: Dalam PostgreSQL 9.2 dan lebih baru, jenis julat khusus tersedia untuk mewakili julat tarikh. Jenis ini membolehkan perbandingan julat bertindih yang cekap dan boleh digunakan untuk mengoptimumkan pertanyaan.
Dengan menggabungkan prinsip ini, pertanyaan yang disemak semula yang disediakan menangani kelemahan pertanyaan asal dan mengenal pasti pemain pasukan tertentu dengan tepat dalam tempoh masa yang ditetapkan:
SELECT DISTINCT name_player
FROM contract
WHERE name_team = ?
AND (date_join, COALESCE(date_leave, CURRENT_DATE)) OVERLAPS
(date '2009-01-01', date '2010-01-01');
Atas ialah kandungan terperinci Bagaimana untuk Mencari Pemain dengan Cekap dalam Pasukan Dalam Julat Tarikh Tertentu dalam PostgreSQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!
Kenyataan: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