Oracle garantit qu'une ligne ne sera pas déplacée physiquement par un update et donc que son ROWID ne sera pas changé. Ce phénomène pourrait en effet survenir dans une table partitionnée avec un update sur la colonne de partitionnement, forçant Oracle à déplacer la ligne dans la bonne partition. (Déplacement physique, changement de ROWID).
Exemple :
SQL> CREATE TABLE toto(a NUMBER)
2 PARTITION BY RANGE (a)(
3 PARTITION p1 VALUES LESS THAN (10),
4 PARTITION p2 VALUES LESS THAN (20),
5 PARTITION p3 VALUES LESS THAN (MAXVALUE));
Table created.
SQL> INSERT INTO toto VALUES (5);
1 row created.
SQL> UPDATE toto SET a=15;
UPDATE toto SET a=15
*
ERROR at line 1:
ORA-14402: updating partition key column would cause a partition change
2 PARTITION BY RANGE (a)(
3 PARTITION p1 VALUES LESS THAN (10),
4 PARTITION p2 VALUES LESS THAN (20),
5 PARTITION p3 VALUES LESS THAN (MAXVALUE));
Table created.
SQL> INSERT INTO toto VALUES (5);
1 row created.
SQL> UPDATE toto SET a=15;
UPDATE toto SET a=15
*
ERROR at line 1:
ORA-14402: updating partition key column would cause a partition change
Pourquoi Oracle provoque-t'il cette erreur ?
A priori on ne voit pas de raison pour laquelle on ne pourrait pas tranquillement mettre à jour une table, même sur la colonne de partitionnement, sans provoquer une erreur... Ceci est en fait un héritage, qu'Oracle nous a transmis pour que lors de l'introduction de tables partitionnées, les programmes qui utilisaient les ROWID n'aient pas de mauvaise surprise en partitionnant leurs tables. Le changement du ROWID lors d'un update pouvant être catastrophique avec ce genre de conception de programme.
Mais comment faire alors ?
Par défaut, donc, Oracle empêche les mises à jour des colonnes de partitionnement des tables partitionnées. Pour autoriser ces mises à jour, il est donc nécessaire de passer la commande ENABLE ROW MOVEMENT en préalable :
Exemple :
SQL> ALTER TABLE toto ENABLE ROW MOVEMENT;
Table altered.
SQL> UPDATE toto SET a=15;
1 row updated.
Table altered.
SQL> UPDATE toto SET a=15;
1 row updated.
Bien qu'il existe la commande inverse qui rétablit l'impossibilité de mettre à jour ces colonnes (DISABLE ROW MOVEMENT), si aucun de vos programmes n'utilise les ROWID, il n'est pas nécessaire de repasser les tables en mode par défaut (disable).
Voici tout de même la commande :
SQL> ALTER TABLE toto DISABLE ROW MOVEMENT;
Table altered.
Table altered.
Aucun commentaire:
Enregistrer un commentaire