SQL Server ile ilgili her şey.

SQL Server’da İki Tarih Arasında Hafta Sonu Olmayan Günleri Listeleyen Fonksiyon

S

Herkese merhaba,

Bu yazıda SQL Server’da iki tarih arasında hafta sonu olmayan günleri listeleyen fonksiyon hakkında bilgi vereceğim.

SQL Server’da bazı durumlarda iki tarih arasında hafta sonu olmayan günleri listelemek isteyebiliriz.

Aşağıdaki fonksiyon yardımıyla bu işlemi rahatlıkla yapabilirsiniz.

CREATE FUNCTION IkiTarihArasindakiHaftaSonuOlmayanGunleriListele
(
    @BaslangicTarihi DATE,
    @BitisTarihi DATE
)
RETURNS TABLE
AS
RETURN WITH N1 (N)
       AS (SELECT 1
           FROM
           (
               VALUES
                   (1),
                   (1),
                   (1),
                   (1),
                   (1),
                   (1),
                   (1),
                   (1),
                   (1),
                   (1)
           ) n (N) ),
            N2 (N)
       AS (SELECT 1
           FROM N1 AS N1
               CROSS JOIN N1 AS N2),
            N3 (N)
       AS (SELECT 1
           FROM N2 AS N1
               CROSS JOIN N2 AS N2),
            N4 (N)
       AS (SELECT ROW_NUMBER() OVER (ORDER BY N1.N)
           FROM N3 AS N1
               CROSS JOIN N3 AS N2)
SELECT Date = DATEADD(DAY, N - 1, @BaslangicTarihi)
FROM N4
WHERE N < DATEDIFF(DAY, @BaslangicTarihi, @BitisTarihi) + 2
      AND DATEDIFF(DAY, 1 - N, @BaslangicTarihi) % 7 NOT IN ( 5, 6 );
GO


--Kullanımı

SELECT *
FROM dbo.IkiTarihArasindakiHaftaSonuOlmayanGunleriListele('20200501', '20200531');

Fonksiyonu oluşturup çalıştırdığınızda aşağıdaki gibi bir sonuç göreceksiniz.

Görüldüğü üzere iki tarih arasında hafta sonu olmayan günler listelenmiş oldu.

Herkese çalışma hayatında ve yaşamında başarılar kolaylıklar.

SQL Server Eğitimleri Kanalına Abone Olun

Yazar Hakkında

Yavuz Selim Kart

SQL Server tarafında kendini ilerletmeye çalışırken bildiklerini sürekli başkalarına aktaran, yazılım dünyasında (C#, Java, Python vb.) kendini güncel tutmaya çalışan, araştırma yapmaktan bıkmayan, meraklı, bilginin üzerine bilgi katmaktan mutluluk duyan bir yazılım eğitmeni ve kod sever.
Grafik tasarım dünyasında Indesign'ı anlatacak kadar iyi kullanabilen, Photoshop ve Illustrator'e de orta düzey hakimiyeti bulunan, internet üzerinde online kimya dergisi kurmuş ve bunu yüzbinlerce kişiye ulaştırmayı başaran bir grafik sever.
WordPress tarafında 5 adet web sitesi kurmuş, bu sistemler üzerine çalışan bir WordPress sever.
Sosyal medya üzerinde okumalara ve araştırmalara devam eden, kendi kurmuş olduğu kimya dergisini daha çok kişiye nasıl ulaştırırım diye düşünen ve bu konuda SEO çalışmaları üzerine kafa yoran bir Sosyal Medya sever.
Kısaca çok çalışmayı seven, azimli biriyim.

Yavuz Selim Kart
SQL Server ile ilgili her şey.

Yazar

Yavuz Selim Kart

SQL Server tarafında kendini ilerletmeye çalışırken bildiklerini sürekli başkalarına aktaran, yazılım dünyasında (C#, Java, Python vb.) kendini güncel tutmaya çalışan, araştırma yapmaktan bıkmayan, meraklı, bilginin üzerine bilgi katmaktan mutluluk duyan bir yazılım eğitmeni ve kod sever.
Grafik tasarım dünyasında Indesign'ı anlatacak kadar iyi kullanabilen, Photoshop ve Illustrator'e de orta düzey hakimiyeti bulunan, internet üzerinde online kimya dergisi kurmuş ve bunu yüzbinlerce kişiye ulaştırmayı başaran bir grafik sever.
WordPress tarafında 5 adet web sitesi kurmuş, bu sistemler üzerine çalışan bir WordPress sever.
Sosyal medya üzerinde okumalara ve araştırmalara devam eden, kendi kurmuş olduğu kimya dergisini daha çok kişiye nasıl ulaştırırım diye düşünen ve bu konuda SEO çalışmaları üzerine kafa yoran bir Sosyal Medya sever.
Kısaca çok çalışmayı seven, azimli biriyim.