Memenggal cap masa ke sempadan tertentu ialah operasi yang kerap dalam pemprosesan pangkalan data. Untuk Postgres, fungsi date_trunc menyediakan cara yang mudah untuk membulatkan cap masa kepada jam atau minit. Walau bagaimanapun, pemangkasan kepada selang 5 minit yang terdekat memerlukan pendekatan yang lebih tersuai.
Pendekatan Lurus
Penyelesaian biasa untuk pemangkasan 5 minit ialah menggabungkan date_trunc dengan operasi bahagi dan darab integer:
date_trunc('hour', val) + date_part('minute', val)::int / 5 * interval '5 min'
Alternatif Kaedah
Dua kaedah alternatif wujud untuk memotong cap masa kepada selang 5 minit:
Kaedah 1: Epoch Aritmetik
Kaedah ini mengira cap waktu dengan menukarkannya kepada masa zaman/unix, membulatkannya ke bawah kepada 5 minit terdekat selang waktu, dan kemudian menukarnya kembali kepada cap waktu. Pertanyaan berikut menunjukkan pendekatan ini:
SELECT to_timestamp( floor(EXTRACT(epoch FROM ht.time) / EXTRACT(epoch FROM interval '5 min')) * EXTRACT(epoch FROM interval '5 min') ) FROM huge_table AS ht
Kaedah 2: date_trunc dan date_part
Kaedah ini serupa dengan pendekatan mudah, tetapi ia menggunakan date_trunc dan date_part secara berasingan untuk mencapai pembundaran. Pertanyaan berikut menggambarkan kaedah ini:
SELECT date_trunc('hour', ht.time) + date_part('minute', ht.time)::int / 5 * interval '5 min' FROM huge_table AS ht
Perbandingan Prestasi
Ujian prestasi pada jadual besar mendedahkan bahawa pendekatan mudah mengatasi kedua-dua kaedah alternatif. Keputusan menunjukkan:
Method | Run 1 (seconds) | Run 2 (seconds) | Run 3 (seconds) |
---|---|---|---|
Epoch Arithmetic | 39.368 | - | 39.526 |
date_trunc and date_part | 34.189 | - | 37.028 |
Kesimpulan
Walaupun kaedah alternatif menawarkan sedikit kepelbagaian dan kesederhanaan, pendekatan mudah menggunakan date_trunc dan date_part menyediakan penyelesaian terpantas untuk memotong cap waktu hingga selang 5 minit dalam Postgres.
Atas ialah kandungan terperinci Bagaimana untuk Memotong Cap Masa dengan Cekap kepada Selang 5 Minit dalam PostgreSQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!