Bu makalede MSSQL Server İkinci Log Dosyasını Silmek – Empty file by migrating the data to other files in the same filegroup konusunu detaylı bir şekilde görmüş olacağız. Bir önceki makale yapmış olduğumuz ikinci bir log dosyası oluşturup sorun giderildikten sonra, tekrardan ilk log dosyamızı kullanmak için sonradan oluşturulan ikinci log dosyamızdaki veriler ilk log dosyamızın üzerine yazılacak. Daha sonra ikinci log dosyamızı silme işlemini ele alacağız. Neden ikinci bir log dosyası oluşturmamız gerektiğini ikinci bir log dosyası oluşturmak konulu makalemde belirtmiştim. Bu yapıyı sağlayacak olan bölüm shrink işleminde 3. Kısımda bulunan Empty file by migrating the data to other files in the same filegroup yöntemi olmuş olacak.

Şimdi uygulamalı bir şekilde oluşturmuş olduğum ikinci log dosyasını ilk log dosyası üzerine atalım.
İkinci log dosyasında shrink işlemi yaparak boş alanları işletim sistemini iade ediyorum. Log dosyasının boşalması için shrink işleminden önce bir log backup alıyorum. Birden fazlada alınabilir.
Not: İlk log dosyasının üzerine shrink edilmeden önce ilk log dosyasında shrink edilmesi gerekmektedir.

Log backup aldıktan sonra veritabanının üzerine sağ tıklayıp Task>Shrink>Files sekmesine geliyorum.

Gelen ekranda file type kısmında log seçtikten sonra file name kısmında shrink yapacağımız ikinci log dosyamızı seçiyorum.
Shrink action kısmından da, Empty file by migrating the data to other files in the same filegroup seçeneğini seçiyoruz. Bu şekilde log dosyamızın içindeki verilerin diğer log dosyasına aktarılmasını sağlamış oluyoruz.
File name kısmında kaç tane log dosyamız varsa hepsi görülmektedir.

Yukarıdaki arayüzün scriptini alıyoruz. Silme işlemiyle aynı anda yapmamız gerekiyor log dosyasına herhangi bir veri yazılmasın.
USE [TEST2]
GO
DBCC SHRINKFILE (N'TEST2_log2 ' , EMPTYFILE)
GO
Yukarıdaki çıktıyı aldıktan sonra ilgili database üzerine sağ tıklayıp properties ekranından ilgili log dosyasının silme işlemi için create scriptini alıyorum. Remove deyip sildikten sonra üst tarafta bulunan Script kısmına tıklıyorum. Scriptini bu şekilde alıyoruz.

use [master];
GO
USE [TEST2]
GO
ALTER DATABASE [TEST2] REMOVE FILE [TEST2_log2 ]
GO
Hem shrink işlemi için aldığımız kodu hem de ikinci log dosyasını silme script’ini alt alta alıyorum.
USE [TEST2]
GO
DBCC SHRINKFILE (N'TEST2_log2 ' , EMPTYFILE)
GO
ALTER DATABASE [TEST2] REMOVE FILE [TEST2_log2 ]
GO
Yukarıdaki komutu çalıştırdıktan sonra ilk log dosyamın enable autogrowth değerini aktif ediyorum. Dikkat ederseniz None olarak görülmektedir.

Yukarıdaki silme işleminde ne kadar ikinci log dosyamızı None yapsak bile yukarıdaki empty file komutunu çalıştırdığımızda hata mesajı alınmaktadır. Bu hata mesajı silmeye çalıştığımızda ikinci log dosyasının üzerinden aktif vlf olduğu için silinememektedir.
Msg 5042, Level 16, State 2, Line 5
The file ‘TEST2_log’ cannot be removed because it is not empty.
Bu işlemleri yaptıktan sonra veritabanı altında silmemize rağmen ikinci log uzantısı görülmeye devam edecektir. Belli süre sonra tek log dosyasının olduğunu göreceksiniz.

Artık veritabanımız ilk log dosyasından büyümeye devam etmiş oluyor. Veritabanı altında gereksiz yere oluşan log yığınından kurtulmuş oluyoruz.
Başka bir makalede görüşmek dileğiyle..
İnkâr edenlere gelince; onların amelleri ıssız bir çöldeki serap gibidir. Susamış kimse onu su sanır. Yanına geldiğinde hiçbir şey bulamaz. (Tıpkı bunun gibi kâfir de hesap günü amellerinden bir şey bulamaz). Ancak Allah’ı yanında bulur da Allah onun hesabını tastamam görür. Allah hesabı çabuk görendir. Nûr -39
1 thought on “MSSQL Server İkinci Log Dosyasını Silmek – Empty file by migrating the data to other files in the same filegroup”