Bagaimana Mengira Kejadian Hari Tertentu Antara Dua Tarikh dalam TSQL?

Patricia Arquette
Lepaskan: 2024-10-31 06:13:30
asal
646 orang telah melayarinya

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>
Salin selepas log masuk

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!

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
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!