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

Administration Oracle Discussion :

[10g] Suppression d'une table temporaire


Sujet :

Administration Oracle

  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Février 2005
    Messages
    283
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 283
    Par défaut [10g] Suppression d'une table temporaire
    Bonjour,

    Je n'arrive pas à supprimer une table temporaire bien que celle ci soit vide et ne soit pas lockée :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    12:41:13 SQL> drop table act_prev_temporary_final;
    drop table act_prev_temporary_final
               *
    ERREUR à la ligne 1 :
    ORA-14452: attempt to create, alter or drop an index on temporary table already in use
    Des idées ?

    Merci par avance,
    A.Personnat

  2. #2
    Membre Expert Avatar de fatsora
    Profil pro
    Inscrit en
    Février 2006
    Messages
    1 103
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2006
    Messages : 1 103

  3. #3
    Membre éclairé
    Profil pro
    Inscrit en
    Février 2005
    Messages
    283
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 283
    Par défaut
    Merci pour ta réponse, mais comme je l'ai indiqué dans mon post la table est vide et non lockée donc cette solution ne s'applique pas dans le cas présent.

    Une autre idée ?

    Cdt,
    A.Personnat

  4. #4
    Membre Expert Avatar de fatsora
    Profil pro
    Inscrit en
    Février 2006
    Messages
    1 103
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2006
    Messages : 1 103
    Par défaut
    Session 1

    CREATE global TEMPORARY TABLE t2 (n number) ON commit preserve rows;

    17-NOV-08 : > insert into t2 values (1);

    1 row created.

    17-NOV-08 : > commit;

    Commit complete.
    >


    Session 2 sous TOAD

    select * from t2;

    0 ligne

    drop table t2;

    ora-11452 .....

    -------------------------------------

    session 1

    truncate table t2;


    session 2

    drop table 2

    OK

    ====> il faut que les toutes les sessions sortent

  5. #5
    Membre Expert Avatar de fatsora
    Profil pro
    Inscrit en
    Février 2006
    Messages
    1 103
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2006
    Messages : 1 103
    Par défaut
    peut etre autre choise

    utiliser DELETE ROWS

    Session 1

    CREATE GLOBAL TEMPORARY TABLE T3 (
    column1 NUMBER,
    column2 NUMBER
    ) ON COMMIT DELETE ROWS;


    insert into T3 values (1,1);
    commit;

    session 2
    17-NOV-08 : user@test > drop table T3;

    Table dropped.

  6. #6
    Membre Expert

    Homme Profil pro
    Chef de projet en SSII
    Inscrit en
    Janvier 2004
    Messages
    2 862
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Chef de projet en SSII
    Secteur : Conseil

    Informations forums :
    Inscription : Janvier 2004
    Messages : 2 862
    Par défaut
    Citation Envoyé par apersonnat Voir le message
    Merci pour ta réponse, mais comme je l'ai indiqué dans mon post la table est vide et non lockée donc cette solution ne s'applique pas dans le cas présent.
    As-tu au moins essayé ce qui est indiqué dans le post ?
    Que la table soit vide ne suffit pas. Il faut faire un truncate en plus.

    @fatsora : merci de penser à utiliser les balises code (# dans la toolbar) cela facilite la lecture

  7. #7
    Membre éclairé
    Profil pro
    Inscrit en
    Février 2005
    Messages
    283
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 283
    Par défaut
    C'était simplement une précision

    Je pense en revanche que la deuxième solution est la bonne à savoir que toutes les sessions soient déconnectées. Il se peut effectivement que l'une de ces sessions ait inséré des données.

    Donc merci à vous pour vos réponses, je vais délester ce post en attendant de pouvoir tester la solution ce qui ne saurait tarder.

    Merci,
    A.Personnat

Discussions similaires

  1. Récupérer le résultat d'une PS dans une table temporaire ?
    Par maitrebn dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 13/02/2006, 09h24
  2. Réponses: 12
    Dernier message: 21/10/2005, 14h35
  3. Problème de suppression dans une table
    Par Splinter dans le forum Bases de données
    Réponses: 3
    Dernier message: 17/10/2005, 10h55
  4. [débutant] Résultat d'un exec dans une table temporaire
    Par amelie15 dans le forum Langage SQL
    Réponses: 4
    Dernier message: 17/08/2005, 09h14
  5. Combler les trous lors d'une suppression dans une table
    Par Billybongjoe dans le forum PostgreSQL
    Réponses: 5
    Dernier message: 08/04/2004, 14h02

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