Précédent   Forum des professionnels en informatique > Bases de données > Oracle
Oracle Forum Oracle : le serveur, les outils, ... Voir F.A.Q Oracle Tutoriels Oracle
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 21/02/2011, 18h13   #1
Invité de passage
 
Inscription : février 2011
Messages : 8
Détails du profil
Informations personnelles :
Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

Informations forums :
Inscription : février 2011
Messages : 8
Points : 0
Points : 0
Par défaut Réduire taille d'un tablespace

Bonjour à tous,

Voici le problème auquel je suis confrontée :

J'ai un tablespace de 32 Go pour lequel j'ai 19 Go de libre, je souhaite récupérer quelque Giga de ce tablespace pour un autre tablespace. Je suis malheureusement limité en espace et ne peut crée un nouveau tablespace afin "d'y mettre les 11 Go " et donc récupérer de l'espace.

Lorsque j'essaye de réduire la taille de mon tablespace j'ai le message d'erreur :
ORA-03297: le fichier contient des données utilisées au-delà de la valeur RESIZE requise

Ci dessous le résulat de select * from DBA_FREE_SPACE_COALESCED where tablespace_name = 'TOTO_TS' :

Code :
1
2
3
4
 
TABLESPACE_NAME                TOTAL_EXTENTS EXTENTS_COALESCED PERCENT_EXTENTS_COALESCED TOTAL_BYTES BYTES_COALESCED TOTAL_BLOCKS BLOCKS_COALESCED PERCENT_BLOCKS_COALESCED
------------------------------ ------------- ----------------- ------------------------- ----------- --------------- ------------ ---------------- ------------------------
TOTO_TS                                  160               160                       100  2,0629E+10      2,0629E+10      2518176          2518176                      100
Afin de pouvoir diminuer l'espace de mon tablespace je pensais faire un :
alter tablespace TOTO_TS coalesce.

Mais je ne suis pas vraiment sûre.

Est ce la bonne solution? Auriez-vous une solution à mon problème?

Merci d'avance
Pourpette est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 21/02/2011, 19h09   #2
Rédacteur
 
Inscription : décembre 2002
Messages : 2 385
Détails du profil
Informations personnelles :
Localisation : France, Var (Provence Alpes Côte d'Azur)

Informations forums :
Inscription : décembre 2002
Messages : 2 385
Points : 3 261
Points : 3 261
Le COALESCE ne vous sera d'aucune aide, car il se contente de fusionner les extensions libres mitoyennes, mais il ne fait aucun déplacement d'extension occupée.
En cas de gruyère avéré et sévère dans votre tablespace, la vraie solution sera une réorganisation classique : exporter tous les objets de ce tablespace, les supprimer et les réimporter.

Selon les outils dont vous disposez, vous pouvez visualiser une carte des tablespaces (quel objet se situe à quel endroit).
Sinon il faut faire l'état des lieux en SQL pour savoir quels sont les objets en fin de fichier.
Cette page pourrait vous y aider :
http://www.pythian.com/news/563/orac...fashioned-way/
__________________
Consultant / formateur Oracle indépendant
Certifié OCP 10g et 11g, sécurité 11g
Pomalaix est déconnecté   Envoyer un message privé Réponse avec citation 10
Vieux 22/02/2011, 11h13   #3
Invité de passage
 
Inscription : février 2011
Messages : 8
Détails du profil
Informations personnelles :
Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

Informations forums :
Inscription : février 2011
Messages : 8
Points : 0
Points : 0
Bonjour,

Merci pour votre réponse.
Je vais donc passer par la solution classique...

J'aurai du coup une question concernant l'insertion d'objet dans un tablespace, y-t-il une "bonne manière" d'insérer les objets afin d'éviter un maximum les "trous" dans le tablespace?
Pourpette est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 22/02/2011, 12h10   #4
Rédacteur
 
Inscription : décembre 2002
Messages : 2 385
Détails du profil
Informations personnelles :
Localisation : France, Var (Provence Alpes Côte d'Azur)

Informations forums :
Inscription : décembre 2002
Messages : 2 385
Points : 3 261
Points : 3 261
Citation:
Envoyé par Pourpette Voir le message
y-t-il une "bonne manière" d'insérer les objets afin d'éviter un maximum les "trous" dans le tablespace?
A mon sens, non.
D'où viennent les trous ? En quoi sont-ils gênants ?
On crée des trous lors des suppressions d'objets (DROP TABLE / DROP INDEX).
La plupart du temps, ces trous ne dérangent personne, sauf dans votre cas où vous avez besoin de réduire la taille de votre fichier.

En prenant :
_ une extension libre (un trou)
A une extension d'une table A
B une extension d'une table B
C ...

Vous aurez couramment un fichier comme ceci :
AABABBCBAACBBAABCA
On supprime la table B, ça devient :
AA_A__C_AAC__AA_CA

On a une bonne proportion d'espace libre, mais on ne peut pas pour autant réduire le fichier sans tout réorganiser.
__________________
Consultant / formateur Oracle indépendant
Certifié OCP 10g et 11g, sécurité 11g
Pomalaix est déconnecté   Envoyer un message privé Réponse avec citation 10
Vieux 22/02/2011, 17h14   #5
Invité de passage
 
Inscription : février 2011
Messages : 8
Détails du profil
Informations personnelles :
Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

Informations forums :
Inscription : février 2011
Messages : 8
Points : 0
Points : 0
Merci beaucoup pour votre aide
Pourpette 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 13h02.


 
 
 
 
Partenaires

Hébergement Web