Précédent   Forum des professionnels en informatique > Bases de données > MySQL > SQL Procédural
SQL Procédural Forum d'entraide sur les triggers, les procédures stockées et les fonctions en MySQL
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 17/01/2008, 11h47   #1
Membre à l'essai
 
Inscription : février 2004
Messages : 41
Détails du profil
Informations forums :
Inscription : février 2004
Messages : 41
Points : 22
Points : 22
Par défaut Archivages de données

Bonjour à tous,


Je souhaite archiver des données de la façon suivante :

Le but est d'archiver une table par mois. Nous en allons donc en créer une par mois.

Soit une table contenant 3 000 000 enregistrements sur 40 colonnes nommée TABLE_COURANT (InnoDb).
Au 2 janvier 2008, nous voulons transferer les données du mois de décembre vers une table TABLE_200712.

Quel est la meilleure solution en temps de traitement? Sachant qu'il faut faire un "couper/coller" dans une autre table ?

J'ai bien pensé renommer la table TABLE_COURANT en TABLE_200712 puis de transphaser les données du mois de janvier vers une nouvelle table TABLE_COURANT mais la suppression des données du mois de janvier de la table TABLE_200712 prend beaucoup de temps.

Auriez vous une idée miracle ?
Le Singe est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 17/01/2008, 12h55   #2
Rédacteur/Modérateur

 
Avatar de Antoun
 
Homme Antoine Dinimant
Consultant en Business Intelligence
Inscription : octobre 2006
Messages : 5 854
Détails du profil
Informations personnelles :
Nom : Homme Antoine Dinimant
Âge : 42
Localisation : France, Paris (Île de France)

Informations professionnelles :
Activité : Consultant en Business Intelligence
Secteur : Conseil

Informations forums :
Inscription : octobre 2006
Messages : 5 854
Points : 9 540
Points : 9 540
Sur TABLE_COURANT, tu rajoutes une colonne BOOLEAN NOT NULL DEFAULT 0 nommée adetruire. Au lieu de faire un DELETE, tu fais un UPDATE marquant cette colonne à 1 pour le mois copié dans sa table.
La nuit quand il y a du temps, tu lances le DELETE pour toutes les lignes marquées 1 dans adetruire.

Autres pistes :
- faire un COMMIT avant la suppression
- mettre le @@foreign_key_checks à 0 avant la suppressions et le rétablir ensuite
- tester le DELETE LOW PRIORITY et le DELETE QUICK
__________________
Antoun
Expert SQL, BO, Essbase

La bible d'Essbase est parue !
Antoun est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 17/01/2008, 13h23   #3
Membre à l'essai
 
Inscription : février 2004
Messages : 41
Détails du profil
Informations forums :
Inscription : février 2004
Messages : 41
Points : 22
Points : 22
Ok merci, je vais voir avec cette technique
Le Singe est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 12h34.


 
 
 
 
Partenaires

Hébergement Web