IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Oracle Discussion :

Renommage de table et erreur ORA-26563


Sujet :

Oracle

  1. #1
    Membre régulier Avatar de Vince7-7
    Homme Profil pro
    Fondateur et dirigeant de la société Oramatica. http://www.oramatica.com
    Inscrit en
    Janvier 2007
    Messages
    125
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine et Marne (Île de France)

    Informations professionnelles :
    Activité : Fondateur et dirigeant de la société Oramatica. http://www.oramatica.com

    Informations forums :
    Inscription : Janvier 2007
    Messages : 125
    Points : 85
    Points
    85
    Par défaut Renommage de table et erreur ORA-26563
    Bonjour à tous.
    En oracle 10 j'ai une erreur "ORA-26563: renaming this table is not allowed" lorsque j'essaie de renommer une table. Google étant mon ami, j'ai cherché un peu de quoi cela pouvait provenir. Je suis tombé sur une page ou il était dit que cela arrivait parce que la table servait de table maitresse dans une vue matérialisé. J'ai donc supprimer les vm. Mais j'ai toujours cette erreur. De quoi cela vient-il est pour moi un mystère. Par contre si une bonne âme le savait ça m'arrangerait pas mal.
    Merci.

  2. #2
    Expert éminent sénior Avatar de mnitu
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2007
    Messages
    5 611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2007
    Messages : 5 611
    Points : 11 252
    Points
    11 252
    Par défaut
    ORA-26563: renaming this table is not allowed Cause: Attempt to rename a replicated table, an updatable materialized view table or the master table of a materialized view for which a materialized view log has beencreated.
    Action: If desired, unregister the replicated table with dbms_repcat.drop_master_repobject, or use the recommended procedure to rename the master table of a materialized view.

  3. #3
    Membre régulier
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Décembre 2011
    Messages
    52
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Décembre 2011
    Messages : 52
    Points : 116
    Points
    116
    Par défaut
    oui en fait tu dois avoir une materialized view log en plus de tes VM :

    il faut la dropper aussi avant de renommer ta table :

    voici un test :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
     
    SQL> drop materialized view fm1;
     
    Materialized view dropped.
     
    SQL> alter table francky2 rename to francky;
    alter table francky2 rename to francky
    *
    ERROR at line 1:
    ORA-26563: renaming this table is not allowed
     
     
    SQL> drop materialized view log on francky2;
     
    Materialized view log dropped.
     
    SQL> alter table francky2 rename to francky;
     
    Table altered.
    A+
    Franck

  4. #4
    Membre régulier Avatar de Vince7-7
    Homme Profil pro
    Fondateur et dirigeant de la société Oramatica. http://www.oramatica.com
    Inscrit en
    Janvier 2007
    Messages
    125
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine et Marne (Île de France)

    Informations professionnelles :
    Activité : Fondateur et dirigeant de la société Oramatica. http://www.oramatica.com

    Informations forums :
    Inscription : Janvier 2007
    Messages : 125
    Points : 85
    Points
    85
    Par défaut
    Merci de ces premiers éléments de réponse. Par contre si je supprime la vm de log comment je recréé derrière après le renomage de ma table?
    Je m'explique: le but du renomage est de remplacer des tables "normales" par des tables partitionnées. Donc je suis obligé de recréer tous ce qui existait auparavant pour être dans un état identique à celui du départ.

  5. #5
    Membre régulier
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Décembre 2011
    Messages
    52
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Décembre 2011
    Messages : 52
    Points : 116
    Points
    116
    Par défaut
    Et bien si tu ne disposes pas des "create initiaux" tu as plusieurs solutions pour regénérer les ordres create :
    - option sqlfile du datapump
    - utiliser les dbms_metadata package sur tes tables et VM
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    SET LONG 9999999
    SET PAGES 0 LINES 300
    SELECT DBMS_METADATA.GET_DDL ('TABLE', 'matable', 'monschema') sql from dual;
    - reverse sous Power AMC ou autre ...

    Bon, c'est quand mème préférable d'avoir tous les DDL sous la main, ceux qui correspondent à ta base ouverte.

  6. #6
    Membre régulier
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Décembre 2011
    Messages
    52
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Décembre 2011
    Messages : 52
    Points : 116
    Points
    116
    Par défaut
    En l'occurence, pour retrouver le DDL de ta materialized view log il faut chercher les dépendances existantes sur la table, donc utiliser la fonction suivante :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    SELECT DBMS_METADATA.GET_DEPENDENT_DDL ('MATERIALIZED_VIEW_LOG', 'matable', 'monschema') sql FROM dual;
    qui produira un DDL du style :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
      CREATE MATERIALIZED VIEW LOG ON "monschema"."matable"
     PCTFREE 10 PCTUSED 30 INITRANS 1 MAXTRANS 255 LOGGING
      STORAGE(INITIAL 65536 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645
      PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1
      BUFFER_POOL DEFAULT FLASH_CACHE DEFAULT CELL_FLASH_CACHE DEFAULT)
      TABLESPACE "montablespace"
      WITH PRIMARY KEY EXCLUDING NEW VALUES
    Voilà, comme cela tu peux revenir en arrière

    Franck.

  7. #7
    Membre régulier Avatar de Vince7-7
    Homme Profil pro
    Fondateur et dirigeant de la société Oramatica. http://www.oramatica.com
    Inscrit en
    Janvier 2007
    Messages
    125
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine et Marne (Île de France)

    Informations professionnelles :
    Activité : Fondateur et dirigeant de la société Oramatica. http://www.oramatica.com

    Informations forums :
    Inscription : Janvier 2007
    Messages : 125
    Points : 85
    Points
    85
    Par défaut
    Ok merci à vous.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Pb: table partionnée avec erreur= ORA-01688 ?
    Par krilas dans le forum Oracle
    Réponses: 1
    Dernier message: 15/07/2010, 12h56
  2. Réponses: 4
    Dernier message: 21/03/2009, 00h35
  3. erreur ora-04091:table mutante
    Par lido dans le forum PL/SQL
    Réponses: 7
    Dernier message: 09/02/2009, 12h26
  4. truncate table et erreur ORA 02266
    Par tchoimars dans le forum SQL
    Réponses: 1
    Dernier message: 08/01/2009, 18h29

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo