Maison >tutoriels informatiques >connaissances en informatique >Méthodes et étapes de compression des fichiers journaux de base de données

Méthodes et étapes de compression des fichiers journaux de base de données

WBOY
WBOYavant
2024-01-15 12:51:271043parcourir

Méthodes et étapes de compression des fichiers journaux de base de données

Comment compresser les fichiers journaux de base de données

Il existe 3 méthodes spécifiques.

Méthode 1 :

Première étape :

nom de la base de données du journal de sauvegarde avec no_log

ou sauvegarde du nom de la base de données du journal avec truncate_only

-- no_log et truncate_only sont synonymes ici, vous pouvez exécuter n'importe quelle phrase.

Étape 2 :

1. Réduisez toutes les données et fichiers journaux d'une base de données spécifique, exécutez :

base de données rétractable dbcc (nom_base de données,[,target_percent])

-- database_name est le nom de la base de données à réduire ; target_percent est le pourcentage d'espace libre restant requis dans le fichier de base de données après la réduction de la base de données.

2. Réduisez les données ou les fichiers journaux dans une base de données spécifique à la fois, exécutez

dbcc Shrinkfile(file_id,[,target_size])

-- file_id est le numéro d'identification (ID) du fichier à réduire. Pour obtenir l'ID du fichier, utilisez la fonction FILE_ID ou recherchez sysfiles dans la base de données actuelle ; target_size est la taille de fichier souhaitée en mégaoctets (exprimée sous forme d'entier). . S'il n'est pas spécifié, dbcc Shrinkfile réduit la taille du fichier à la taille par défaut. Les deux dbcc peuvent porter le paramètre notruncate ou truncateonly. Veuillez vous référer à l'aide en ligne pour la signification spécifique.

.

Méthode 2 :

Première étape :

Sauvegardez d'abord l'intégralité de la base de données pour vous préparer aux urgences.

Étape 2 :

Une fois la sauvegarde terminée, exécutez l'instruction suivante dans Query Analyzer :

exec sp_detach_db votreDBName,true

--Désinstallez les informations d'enregistrement de cette base de données dans MSSQL

Étape 3 :

Accédez au répertoire où se trouve le fichier journal physique pour supprimer le fichier journal ou déplacer le fichier journal hors du répertoire

Étape 4 :

Exécutez l'instruction suivante dans Query Analyzer :

exec sp_attach_single_file_db yourDBName,'

d:mssqldatayourDBName_data.mdf '

--Enregistrez la base de données en tant que fichier unique. En cas de succès, MSSQL générera automatiquement un fichier journal de 500 Ko pour cette base de données.

Méthode 3 :

1. Entrez le gestionnaire d'entreprise et sélectionnez la base de données, telle que démo

2. Toutes les tâches -> Base de données séparée

3. Accédez au répertoire où le fichier de base de données est stocké et supprimez le fichier MuOnline_log.LDF Juste au cas où, vous pouvez le copier

.

4. Enterprise Manager -> Attacher la base de données, sélectionnez muonline À ce moment, vous verrez que l'élément du fichier journal est une croix, continuez. À ce moment, la base de données vous indiquera qu'elle n'en a pas. logs. Voulez-vous en créer un nouveau ?

5. N'oubliez pas que l'utilisateur doit le réinitialiser une fois la base de données reconnectée.

Si vous ne voulez pas que cela s'agrandisse à l'avenir :

Utilisé sous SQL2000 :

Cliquez avec le bouton droit sur la base de données-> Propriétés-> Options-> Récupération d'échec-Modèle-Sélection-Modèle simple.

Ou utilisez l'instruction SQL :

modifier le nom de la base de données et définir la récupération simple

Que faire si la base de données SQL est trop volumineuse

--1. Compression quotidienne de la base de données

--Compresser la taille du fichier journal et de la base de données

/*--Attention particulière

Veuillez suivre les étapes si vous n'avez pas effectué les étapes précédentes, veuillez ne pas suivre les étapes suivantes

Sinon, cela pourrait endommager votre base de données.

--*/

1.Effacer le journal

NOM de la bibliothèque DUMP TRANSACTION AVEC NO_LOG

2. Tronquer le journal des transactions :

Nom de la base de données BACKUP LOG AVEC NO_LOG

3. Réduisez le fichier de base de données (s'il n'est pas compressé, le fichier de base de données ne sera pas réduit

Enterprise Manager--cliquez avec le bouton droit sur la base de données que vous souhaitez compresser--Toutes les tâches--Réduire la base de données--Réduire les fichiers

--Sélectionnez le fichier journal--Choisissez de réduire à XXM en mode réduction. Il y aura un nombre minimum de M autorisés à être réduits. Entrez ce nombre directement et confirmez.

--Sélectionnez le fichier de données--En mode réduction, sélectionnez réduire à XXM. Il y aura un nombre minimum de M autorisés à être réduits. Entrez directement ce nombre et confirmez.

Cela peut également être fait à l'aide d'instructions SQL

--Réduire la base de données

DBCC SHRINKDATABASE (Données clients)

--Réduire le fichier de données spécifié, 1 est le numéro de fichier, qui peut être interrogé via cette instruction : select * from sysfiles

DBCC SHRINKFILE(1)

4. Afin de minimiser la taille du fichier journal (s'il s'agit de SQL 7.0, cette étape ne peut être effectuée que dans l'analyseur de requêtes)

a. Base de données séparée :

Enterprise Manager--Serveur--Base de données--clic droit--Détacher la base de données

b. Supprimer les fichiers LOG sur mon ordinateur

c. Base de données supplémentaire :

Enterprise Manager--Serveur--Base de données--clic droit--Joindre la base de données

Cette méthode générera un nouveau LOG, la taille n'est que supérieure à 500K

ou utilisez le code :

L'exemple ci-dessous détache les pubs puis ajoute un fichier des pubs au serveur actuel.

a.Séparation

EXEC sp_detach_db @dbname = 'pubs'

b. Supprimer les fichiers journaux

c.Ajouter encore

EXEC sp_attach_single_file_db @dbname = 'pubs',

@physname = 'c:Program FilesMicrosoft SQL ServerMSSQLDatapubs.mdf'

5. Afin de rétrécir automatiquement à l'avenir, effectuez les réglages suivants :

Enterprise Manager--Serveur--cliquez avec le bouton droit sur la base de données--Propriétés--Options--Sélectionnez "Rétrécissement automatique"

--Méthode de configuration des instructions SQL :

EXEC sp_dboption 'nom de la base de données', 'autoshrink', 'TRUE'

6. Si vous souhaitez éviter que le journal ne devienne trop volumineux à l'avenir

Enterprise Manager--Serveur--Clic droit sur la base de données--Propriétés--Journal des transactions

--Limiter la croissance des fichiers à xM (x est la taille maximale du fichier de données que vous autorisez)

--Méthode de configuration des instructions SQL :

modifier le nom de la base de données, modifier le fichier (nom = nom de fichier logique, maxsize = 20)

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer