Rumah > pangkalan data > tutorial mysql > Bagaimanakah Jenis `tsrange` PostgreSQL Boleh Mengoptimumkan Pertanyaan untuk Waktu Perniagaan?

Bagaimanakah Jenis `tsrange` PostgreSQL Boleh Mengoptimumkan Pertanyaan untuk Waktu Perniagaan?

Patricia Arquette
Lepaskan: 2025-01-02 13:19:39
asal
574 orang telah melayarinya

How Can PostgreSQL's `tsrange` Type Optimize Queries for Business Hours?

Melaksanakan Pertanyaan Waktu Operasi dalam PostgreSQL

Dalam PostgreSQL, anda boleh melakukan pertanyaan untuk mencari semua rekod yang "terbuka" berdasarkan waktu operasi tertentu menggunakan gabungan perbandingan tarikh dan masa. Walau bagaimanapun, pendekatan ini boleh menjadi rumit, terutamanya jika waktu bekerja pada penghujung minggu.

Penyelesaian Cadangan Menggunakan Jenis tsrange

Untuk memudahkan dan mengoptimumkan pertanyaan ini, anda boleh mereka bentuk semula jadual untuk menyimpan waktu buka sebagai satu set nilai tsrange (julat cap waktu tanpa zon waktu). Ini memerlukan PostgreSQL versi 9.2 atau lebih baru dan melibatkan langkah berikut:

Reka Letak Jadual:

  • Buat jadual dengan lajur tsrange bernama jam untuk menyimpan waktu buka bukannya lajur berasingan untuk masa buka dan tutup.

Contoh Data:

CREATE TABLE hoo (
  hoo_id  serial PRIMARY KEY
, shop_id int NOT NULL
, hours   tsrange NOT NULL
);
Salin selepas log masuk
  • Waktu operasi untuk hari Rabu 18:30 hingga Khamis 05:00 UTC boleh dimasukkan sebagai:
INSERT INTO hoo(shop_id, hours)
VALUES (123, '[1996-01-03 18:30, 1996-01-04 05:00]');
Salin selepas log masuk

Kekangan Pengecualian:

  • Kekangan pengecualian ditambah untuk mengelakkan entri bertindih setiap kedai menggunakan indeks GiST.

Fungsi Pembantu:

  • Dua fungsi pembantu, f_hoo_time() dan f_hoo_hours(), ditakrifkan untuk menormalkan cap masa dan julat berpecah merentasi Ahad tengah malam.

Pertanyaan Dioptimumkan:

Menggunakan struktur jadual baharu dan fungsi pembantu, anda boleh memudahkan pertanyaan anda kepada:

SELECT *
FROM hoo
WHERE hours @> f_hoo_time(now());
Salin selepas log masuk

Kebaikan:

  • Penggunaan daripada tsrange memudahkan sintaks pertanyaan dan meningkatkan prestasi dengan memanfaatkan indeks yang disokong.
  • Kekangan pengecualian memastikan integriti data dan menghalang entri bertindih.
  • Indeks GiST menyediakan carian pantas dan cekap berdasarkan jam medan.
  • Indeks SP-GiST pada hanya beberapa jam meningkatkan lagi prestasi untuk pertanyaan melibatkan hasil yang banyak.

Atas ialah kandungan terperinci Bagaimanakah Jenis `tsrange` PostgreSQL Boleh Mengoptimumkan Pertanyaan untuk Waktu Perniagaan?. 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