Rumah  >  Artikel  >  pangkalan data  >  Bagaimana Mengira Kejadian Hari Tertentu Antara Dua Tarikh dalam TSQL?

Bagaimana Mengira Kejadian Hari Tertentu Antara Dua Tarikh dalam TSQL?

Patricia Arquette
Patricia Arquetteasal
2024-10-31 06:13:30648semak imbas

How to Count Occurrences of Specific Days Between Two Dates in TSQL?

Mengira Kejadian Hari Tertentu antara Tarikh dalam TSQL

Apabila berurusan dengan pengiraan berkaitan tarikh dalam TSQL, menentukan kekerapan hari bekerja tertentu boleh menjadi cabaran. Satu senario sedemikian melibatkan pengiraan bilangan "Selasa" antara dua tarikh yang diberikan.

Penyelesaian

Untuk mengira bilangan kejadian pada mana-mana hari, termasuk hari Selasa, anda boleh gunakan kod yang disediakan:

<code class="tsql">declare @from datetime= '3/1/2013' 
declare @to datetime  = '3/31/2013' 


select 
 datediff(day, -7, @to)/7-datediff(day, -6, @from)/7 AS MON,
 datediff(day, -6, @to)/7-datediff(day, -5, @from)/7 AS TUE,
 datediff(day, -5, @to)/7-datediff(day, -4, @from)/7 AS WED,
 datediff(day, -4, @to)/7-datediff(day, -3, @from)/7 AS THU,
 datediff(day, -3, @to)/7-datediff(day, -2, @from)/7 AS FRI,
 datediff(day, -2, @to)/7-datediff(day, -1, @from)/7 AS SAT,
 datediff(day, -1, @to)/7-datediff(day, 0, @from)/7 AS SUN</code>

Dalam kod ini, anda boleh menggantikan "Selasa" dengan mana-mana hari lain yang dikehendaki dengan melaraskan kod hari yang sepadan (cth., -6 untuk Selasa).

Dengan memberikan tarikh mula dan tamat, kod ini mengira bilangan kejadian setiap hari dalam tempoh tersebut. Ia menganggap hari mula Isnin (kod -7) dan mengira perbezaan antara bilangan hari yang merupakan gandaan 7 (mis., gandaan hari sejak Isnin) antara tarikh mula dan tamat. Ini secara berkesan mengira kejadian setiap hari dalam julat tarikh yang ditentukan.

Atas ialah kandungan terperinci Bagaimana Mengira Kejadian Hari Tertentu Antara Dua Tarikh dalam TSQL?. 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