Θα ξεκινήσω τα άρθρο μου αυτό τονίζοντας ότι όλα όσα θα αναφερθούν παρακάτω αφορούν εξαιρετικά δύσκολες περιπτώσεις και αποτελούν την τελευταία σανίδα σωτηρίας. Επίσης καλό είναι να έχει γίνει και μια σχετική "προπόνηση" σε περιβάλλον δοκιμών ώστε να είστε σίγουροι για το τι ακριβώς κάνετε και να μην σας λούζει κρύος ιδρώτας.
Ολική καταστροφή ή απώλεια του transaction log.
Είναι η περίπτωση που για Χ λόγους έχουμε χάσει παντελώς το transaction log σε μια database και αυτή εμφανίζεται σαν recovery pending και είτε δεν έχουμε backup γιατί αυτό είναι χαλασμένο, είτε ο χρόνος για να γίνει το restore είναι αρκετά μεγάλος για ένα σύστημα παραγωγής που πρέπει να δουλέψει σχετικά άμεσα.
Σε αυτή την περίπτωση μπορούμε να δημιουργήσουμε ξανά το transaction log με το παρακάτω statement
ALTER DATABASE tsqldemo REBUILD LOG ON (name='tsqlDemo_Log', FILENAME='E:\MSSQL14.DB01.LOG\tsqldemo.ldf', size = 1024MB);
GO
Αυτό μετά από την εκτέλεση του θα μας δώσει ένα Warning που σημαίνει πρέπει να κάνουμε αυτά που λέει άμεσα σαν επόμενο βήμα και τα οποία είναι DBCC CHECKDB , να πάρουμε full backup , να γυρίσουμε αυτή σε multi user mode (ALTER DATABASE tsqldemo SET MULTI_USER;)
Συμμάζεμα του αριθμού των VLFs που έχει το transaction log.
Έχω αναφερθεί αρκετές φορές σε αυτό και με μια απλή αναζήτηση στο SQLschool.gr με τη λέξη VLF θα βρείτε αρκετά για αυτό.
Η δόκιμη λύση είναι να γίνουν τα απαραίτητα transaction log backups και με shrink μόνο το log file να έρθουμε στην κατάσταση που επιθυμούμε.
Αν παρόλα αυτά ο αριθμός των VLFs είναι τέτοιος που θα χρειαστούν πάρα πολλά log backups και εφόσον έχουμε πάντα στην διάθεση μας ενημερωμένο full backup και εφόσον έχουν την δυνατότητα για downtime τότε μπορούμε να κάνουμε τα παρακάτω βήματα εκτελώντας ένα κάθε φορά.
DBCC LOGINFO (tsqldemo);
GO
-- STEP 1
ALTER DATABASE tsqldemo SET EMERGENCY;
GO
-- STEP 2
ALTER DATABASE tsqldemo SET SINGLE_USER;
GO
-- STEP 3
ALTER DATABASE tsqldemo SET OFFLINE;
GO
-- STEP 4
/*
LOCATE TLOG FILE USING WINDOWS EXPLORER AND DELETE IT
*/
-- STEP 5
ALTER DATABASE tsqldemo SET ONLINE;
GO
-- STEP 6
ALTER DATABASE tsqldemo REBUILD LOG ON (name='tsqlDemo_Log', FILENAME='E:\MSSQL14.DB01.LOG\tsqldemo.ldf', size = 1024MB)
GO
-- STEP 7
ALTER DATABASE tsqldemo SET MULTI_USER;
GO
-- STEP 8
DBCC CHECKDB(tsqldemo)
GO
-- STEP 9
-- TAKE FULL BACKUP
//antonch