亚洲国产日韩欧美一区二区三区,精品亚洲国产成人av在线,国产99视频精品免视看7,99国产精品久久久久久久成人热,欧美日韩亚洲国产综合乱

Rumah pangkalan data tutorial mysql Bagaimanakah Saya Boleh Mengira Waktu Kerja Antara Tarikh dalam PostgreSQL, Mempertimbangkan Hujung Minggu dan Waktu Kerja Tertentu?

Bagaimanakah Saya Boleh Mengira Waktu Kerja Antara Tarikh dalam PostgreSQL, Mempertimbangkan Hujung Minggu dan Waktu Kerja Tertentu?

Jan 03, 2025 am 10:35 AM

How Can I Calculate Working Hours Between Dates in PostgreSQL, Considering Weekends and Specific Working Hours?

Mengira Waktu Bekerja Antara Tarikh dalam PostgreSQL

Pengenalan

Dalam pelbagai senario, menentukan bilangan jam bekerja antara dua cap masa boleh terbukti penting dalam bidang seperti gaji dan penjadualan. Dalam PostgreSQL, pengiraan ini memerlukan pertimbangan yang teliti terhadap parameter khusus hari bekerja dan masa. Artikel ini menggariskan penyelesaian yang komprehensif, dengan mengambil kira kriteria berikut:

  • Hujung Minggu (Sabtu dan Ahad) dikecualikan daripada waktu bekerja.
  • Waktu bekerja adalah ditakrifkan sebagai Isnin hingga Jumaat, 8 pagi hingga 3 pm.
  • Waktu pecahan hendaklah dimasukkan dalam pengiraan.

Penyelesaian

Kaedah 1: Bulat Keputusan untuk Hanya Dua Cap Masa

Pendekatan ini beroperasi pada unit 1 jam, mengabaikan jam pecahan. Ia adalah kaedah yang mudah tetapi kurang tepat.

Pertanyaan:

SELECT count(*) AS work_hours
FROM   generate_series (timestamp '2013-06-24 13:30'
                      , timestamp '2013-06-24 15:29' - interval '1h'
                      , interval '1h') h
WHERE  EXTRACT(ISODOW FROM h) < 6
AND    h::time >= '08:00'
AND    h::time &amp;lt;= '14:00';

Contoh Input:

2013-06-24 13:30, 2013-06-24 15:29

Output:

2

Kaedah 2: Keputusan Bulat untuk Jadual Cap Masa

Pendekatan ini memanjangkan kaedah sebelumnya untuk mengendalikan jadual cap masa berpasangan.

Pertanyaan:

SELECT t_id, count(*) AS work_hours
FROM  (
   SELECT t_id, generate_series (t_start, t_end - interval '1h', interval '1h') AS h
   FROM   t
   ) sub
WHERE  EXTRACT(ISODOW FROM h) < 6
AND    h::time >= '08:00'
AND    h::time <= '14:00'
GROUP  BY 1
ORDER  BY 1;

Kaedah 3: Pengiraan Lebih Tepat

Untuk pengiraan yang lebih halus, unit masa yang lebih kecil boleh dipertimbangkan.

Pertanyaan:

SELECT t_id, count(*) * interval '5 min' AS work_interval
FROM  (
   SELECT t_id, generate_series (t_start, t_end - interval '5 min', interval '5 min') AS h
   FROM   t
   ) sub
WHERE  EXTRACT(ISODOW FROM h) < 6
AND    h::time >= '08:00'
AND    h::time <= '14:55'
GROUP  BY 1
ORDER  BY 1;

Contoh Input:

| t_id | t_start                | t_end                  |
|------|-------------------------|-------------------------|
| 1    | 2009-12-03 14:00:00    | 2009-12-04 09:00:00    |
| 2    | 2009-12-03 15:00:00    | 2009-12-07 08:00:00    |
| 3    | 2013-06-24 07:00:00    | 2013-06-24 12:00:00    |
| 4    | 2013-06-24 12:00:00    | 2013-06-24 23:00:00    |
| 5    | 2013-06-23 13:00:00    | 2013-06-25 11:00:00    |
| 6    | 2013-06-23 14:01:00    | 2013-06-24 08:59:00    |

Output:

| t_id | work_interval |
|------|----------------|
| 1    | 1 hour         |
| 2    | 8 hours        |
| 3    | 0 hours        |
| 4    | 0 hours        |
| 5    | 6 hours        |
| 6    | 1 hour         |

Kaedah 4: Tepat Keputusan

Pendekatan ini memberikan hasil yang tepat dengan ketepatan mikrosaat. Ia lebih kompleks tetapi lebih cekap dari segi pengiraan.

Pertanyaan:

WITH var AS (SELECT '08:00'::time  AS v_start
                  , '15:00'::time  AS v_end)
SELECT t_id
     , COALESCE(h.h, '0')  -- add / subtract fractions
       - CASE WHEN EXTRACT(ISODOW FROM t_start) < 6
               AND t_start::time > v_start
               AND t_start::time < v_end
         THEN t_start - date_trunc('hour', t_start)
         ELSE '0'::interval END
       + CASE WHEN EXTRACT(ISODOW FROM t_end) < 6
               AND t_end::time > v_start
               AND t_end::time < v_end
         THEN t_end - date_trunc('hour', t_end)
         ELSE '0'::interval END                 AS work_interval
FROM   t CROSS JOIN var
LEFT   JOIN (  -- count full hours, similar to above solutions
   SELECT t_id, count(*)::int * interval '1h' AS h
   FROM  (
      SELECT t_id, v_start, v_end
           , generate_series (date_trunc('hour', t_start)
                            , date_trunc('hour', t_end) - interval '1h'
                            , interval '1h') AS h
      FROM   t, var
      ) sub
   WHERE  EXTRACT(ISODOW FROM h) < 6
   AND    h::time >= v_start
   AND    h::time <= v_end - interval '1h'
   GROUP  BY 1
   ) h USING (t_id)
ORDER  BY 1;

Penyelesaian komprehensif ini menangani keperluan untuk mengira waktu bekerja dengan tepat dan cekap dalam PostgreSQL.

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mengira Waktu Kerja Antara Tarikh dalam PostgreSQL, Mempertimbangkan Hujung Minggu dan Waktu Kerja Tertentu?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

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

Alat AI Hot

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Mewujudkan sambungan jauh yang selamat ke pelayan MySQL Mewujudkan sambungan jauh yang selamat ke pelayan MySQL Jul 04, 2025 am 01:44 AM

TosecurelyConnecttoaremotemysqlserver, usesshtunneling, configuremysqlforremoteaccess, setfirewallrules, andconsidersslencryption .First, DesiglishansshtunnelWithSSH-L3307: localhost: 3306user@remote-server-nandconnectviamysql-h127.0.0.1-p3307.second, editmys

Memahami peranan kunci asing dalam integriti data MySQL Memahami peranan kunci asing dalam integriti data MySQL Jul 03, 2025 am 02:34 AM

ForeignkeysinMySQLensuredataintegritybyenforcingrelationshipsbetweentables.Theypreventorphanedrecords,restrictinvaliddataentry,andcancascadechangesautomatically.BothtablesmustusetheInnoDBstorageengine,andforeignkeycolumnsmustmatchthedatatypeoftherefe

Melakukan sandaran logik menggunakan mysqldump di mysql Melakukan sandaran logik menggunakan mysqldump di mysql Jul 06, 2025 am 02:55 AM

MySQLDUMP adalah alat yang biasa untuk melakukan sandaran logik pangkalan data MySQL. Ia menjana fail SQL yang mengandungi penyataan CREATE dan INSERT untuk membina semula pangkalan data. 1. Ia tidak menyandarkan fail asal, tetapi menukarkan struktur dan kandungan pangkalan data ke dalam arahan SQL mudah alih; 2. Ia sesuai untuk pangkalan data kecil atau pemulihan selektif, dan tidak sesuai untuk pemulihan data tahap TB yang cepat; 3. Pilihan biasa termasuk--single-transaksi,-databases,-semua data,-routin, dan sebagainya; 4. Gunakan perintah MySQL untuk mengimport semasa pemulihan, dan boleh mematikan cek utama asing untuk meningkatkan kelajuan; 5. Adalah disyorkan untuk menguji sandaran secara teratur, menggunakan mampatan, dan pelarasan automatik.

Menganalisis log pertanyaan perlahan MySQL untuk mencari kemunculan prestasi Menganalisis log pertanyaan perlahan MySQL untuk mencari kemunculan prestasi Jul 04, 2025 am 02:46 AM

Hidupkan log pertanyaan perlahan MySQL dan menganalisis isu prestasi lokasi. 1. Edit fail konfigurasi atau ditetapkan secara dinamik SLOW_QUERY_LOG dan LONG_QUERY_TIME; 2. Log mengandungi medan utama seperti query_time, lock_time, rows_examined untuk membantu menilai kesesakan kecekapan; 3. Gunakan alat mysqldumpslow atau pt-query-digest untuk menganalisis log dengan cekap; 4. Cadangan pengoptimuman termasuk menambah indeks, mengelakkan pilih*, memisahkan pertanyaan kompleks, dan lain -lain. Sebagai contoh, menambah indeks ke user_id dapat mengurangkan jumlah baris yang diimbas dan meningkatkan kecekapan pertanyaan.

Mengendalikan nilai null dalam lajur dan pertanyaan MySQL Mengendalikan nilai null dalam lajur dan pertanyaan MySQL Jul 05, 2025 am 02:46 AM

Apabila mengendalikan nilai null dalam MySQL, sila ambil perhatian: 1. Apabila mereka bentuk jadual, medan utama ditetapkan kepada notnull, dan bidang pilihan dibenarkan NULL; 2. Isnull atau Isnotnull mesti digunakan dengan = atau! =; 3. Fungsi Ifnull atau Coalesce boleh digunakan untuk menggantikan nilai lalai paparan; 4. Berhati -hati apabila menggunakan nilai null secara langsung apabila memasukkan atau mengemas kini, dan perhatikan sumber data dan kaedah pemprosesan rangka kerja ORM. Null mewakili nilai yang tidak diketahui dan tidak sama dengan nilai, termasuk dirinya sendiri. Oleh itu, berhati -hati apabila menanyakan, menghitung, dan menghubungkan jadual untuk mengelakkan data yang hilang atau kesilapan logik. Penggunaan fungsi dan kekangan yang rasional dapat mengurangkan gangguan yang disebabkan oleh null.

Menetapkan semula kata laluan root untuk pelayan mysql Menetapkan semula kata laluan root untuk pelayan mysql Jul 03, 2025 am 02:32 AM

Untuk menetapkan semula kata laluan root MySQL, sila ikuti langkah -langkah berikut: 1. Hentikan pelayan MySQL, gunakan sudosystemctlstopmysql atau sudosystemctlstopmysqld; 2. Mulakan MySQL In-Skip-Grant-Tables Mode, laksanakan sudomysqld-skip-gergaji meja &; 3. Log masuk ke MySQL dan laksanakan perintah SQL yang sepadan untuk mengubah suai kata laluan mengikut versi, seperti flushprivileges; alteruser'root '@' localhost'identifiedby'your_new

Mengira Pangkalan Data dan Saiz Jadual di MySQL Mengira Pangkalan Data dan Saiz Jadual di MySQL Jul 06, 2025 am 02:41 AM

Untuk melihat saiz pangkalan data dan jadual MySQL, anda boleh menanyakan maklumat_schema secara langsung atau gunakan alat baris arahan. 1. Semak keseluruhan saiz pangkalan data: Laksanakan pernyataan SQL selecttable_schemaas'database ', jumlah (data_length index_length)/1024/1024as'size (mb)' dari formation_schema.tablesgroupbytable_schema; Anda boleh mendapatkan saiz keseluruhan semua pangkalan data, atau menambah di mana syarat untuk mengehadkan pangkalan data tertentu; 2. Periksa saiz jadual tunggal: gunakan selectta

Mengendalikan set watak dan isu pengumpulan di MySQL Mengendalikan set watak dan isu pengumpulan di MySQL Jul 08, 2025 am 02:51 AM

Peraturan Peraturan dan Penyortiran Isu-isu adalah perkara biasa apabila penghijrahan silang platform atau pembangunan berbilang orang, mengakibatkan kod yang tidak konsisten atau pertanyaan yang tidak konsisten. Terdapat tiga penyelesaian teras: pertama, periksa dan menyatukan set aksara pangkalan data, jadual, dan medan ke UTF8MB4, melihat melalui showcreatedatabase/jadual, dan mengubahnya dengan pernyataan alter; kedua, tentukan set aksara UTF8MB4 apabila pelanggan menghubungkan, dan tetapkannya dalam parameter sambungan atau laksanakan setnames; Ketiga, pilih peraturan penyortiran yang munasabah, dan cadangkan menggunakan UTF8MB4_UNICODE_CI untuk memastikan ketepatan perbandingan dan penyortiran, dan tentukan atau mengubahnya melalui Alter ketika membina perpustakaan dan jadual.

See all articles