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 24/07/2007, 17h34   #1
Membre du Club
 
Avatar de Bahan
 
Inscription : avril 2006
Messages : 147
Détails du profil
Informations personnelles :
Âge : 32

Informations forums :
Inscription : avril 2006
Messages : 147
Points : 54
Points : 54
Envoyer un message via MSN à Bahan
Par défaut [Oracle 10.2] Sequence & import

Bonjour à toutes et à tous.

J'ai un petit soucis sur Oracle.
Voilà le topo.

J'ai fait un export/import d'une base.
Cette base contient entre autre une séquence.

Or cette séquence, après import, n'est pas à jour, ce qui provoque un plantage en règle d'un de mes traitements qui me retourne une erreur de violation de contrainte unique.

Mon parfile :
Code :
1
2
3
4
5
6
7
8
BUFFER=4096
GRANTS=Y
INDEXES=Y
ROWS=Y
CONSTRAINTS=Y
COMPRESS=N
FULL=Y
CONSISTENT=N
J'aurais donc aimé savoir :
1. si les séquences sont bien exportées lors d'un export.
2. comment mettre à jour proprement une séquence après un import ?

Merci d'avance pour vos réponses.

Cdt.

Bahan
Bahan est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 24/07/2007, 17h45   #2
Expert Confirmé
 
Inscription : février 2006
Messages : 3 433
Détails du profil
Informations forums :
Inscription : février 2006
Messages : 3 433
Points : 3 462
Points : 3 462
Les séquences sont exportées oui mais pas forcément avec la bonne valeur:

Citation:
Exporting Sequences
If transactions continue to access sequence numbers during an export, sequence numbers might be skipped. The best way to ensure that sequence numbers are not skipped is to ensure that the sequences are not accessed during the export.

Sequence numbers can be skipped only when cached sequence numbers are in use. When a cache of sequence numbers has been allocated, they are available for use in the current database. The exported value is the next sequence number (after the cached values). Sequence numbers that are cached, but unused, are lost when the sequence is imported.
Pour les mettre à jour, il faut écrire un script pour:
- récupérer une bonne valeur pour chaque séquence
- mettre à jour la séquence: voir http://www.developpez.net/forums/sho....php?t=319906&
__________________
P. Forstmann

AskTom Forums OTN doc 8, 9, 10 et 11
pifor est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 24/07/2007, 18h05   #3
Membre du Club
 
Avatar de Bahan
 
Inscription : avril 2006
Messages : 147
Détails du profil
Informations personnelles :
Âge : 32

Informations forums :
Inscription : avril 2006
Messages : 147
Points : 54
Points : 54
Envoyer un message via MSN à Bahan
Ok, merci pour l'information.

J'ai donc vu ce qu'il me fallait faire.
1. Récupérer la plus haute valeur que j'ai dans ma table qui utilise la séquence.
2. Récupérer la valeur actuelle de ma séquence
3. Faire la différence des deux
4. Augmenter le pas de ma séquence :
Code :
ALTER sequence masequence increment BY Difference;
5. Passer à la valeur suivante de la séquence
Code :
SELECT masequence.NEXTVAL FROM dual ;
6. Remettre le pas à 1
Code :
ALTER sequence masequence increment BY 1 ;
Est-ce que cela n'irait pas plus vite de faire un :
1. Récupérer la plus haute valeur de clef primaire que j'ai dans la table qui utilise la séquence.
2. Supprimer la séquence
Code :
 DROP sequence masequence;
3. Recréer la séquence en commençant au maximum que j'ai relevé +1
Code :
CREATE sequence masequence start WITH MaxValeur+1
Est-ce que cela reste propre aussi ?

Cdt.

Bahan
Bahan est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 24/07/2007, 18h10   #4
Membre Expert
 
Avatar de Garuda
 
Homme Philippe CHIRCOP
Chef de projet
Inscription : juin 2007
Messages : 1 109
Détails du profil
Informations personnelles :
Nom : Homme Philippe CHIRCOP
Localisation : France

Informations professionnelles :
Activité : Chef de projet
Secteur : Bâtiment

Informations forums :
Inscription : juin 2007
Messages : 1 109
Points : 1 559
Points : 1 559
Tout a fait propre (et plus simple)
__________________
Garuda गरूड
Brahmâ la Guerre et Vishnu la Paix

Oracle 10.2.0.4 - Forms6i patch 17 - Toad 11.1 - sharePoint 2010
Garuda 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 12h43.


 
 
 
 
Partenaires

Hébergement Web