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 :

Drop de toutes les tables d'un schéma sans supprimer le schéma?


Sujet :

Oracle

  1. #1
    Membre à l'essai
    Inscrit en
    Octobre 2011
    Messages
    16
    Détails du profil
    Informations forums :
    Inscription : Octobre 2011
    Messages : 16
    Points : 14
    Points
    14
    Par défaut Drop de toutes les tables d'un schéma sans supprimer le schéma?
    Bonjour,

    Ma question est celle de l'intitulé.

    Est-il possible de "droper" toutes les tables d'un schéma, sans supprimer le schéma?
    Et bien sur, si oui, comment est ce possible?

    J'utilise sqlplus.

    Merci
    A bientôt.

  2. #2
    Inactif  

    Homme Profil pro
    Freelance EURL / Business Intelligence ETL
    Inscrit en
    Avril 2005
    Messages
    5 879
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Freelance EURL / Business Intelligence ETL
    Secteur : Finance

    Informations forums :
    Inscription : Avril 2005
    Messages : 5 879
    Points : 26 147
    Points
    26 147
    Billets dans le blog
    3
    Par défaut
    Créer une procédure qui liste l'ensemble des tables de ton user, puis droper séquentiellement ces tables les unes après les autres.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select * from all_tables where owner = 'MON_SCHEMA'
    - So.... what exactly is preventing us from doing this?
    - Geometry.
    - Just ignore it !!
    ****
    "The longer he lived, the more he realized that nothing was simple and little was true" A clash of Kings, George R. R. Martin.
    ***
    Quand arrivera l'apocalypse, il restera deux types d'entreprise : les pompes funèbres et les cabinets d'audit. - zecreator, 21/05/2019

  3. #3
    Membre régulier
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Mai 2011
    Messages
    47
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Mai 2011
    Messages : 47
    Points : 110
    Points
    110
    Par défaut
    Bonjour,

    Comme indiqué par Glutinus il suffit de parcourir les tables du schémas voulu à l'aide d'une boucle et de construire dynamiquement les ordres de suppression des tables.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    BEGIN
        FOR f IN (SELECT table_name FROM ALL_TABLES WHERE OWNER = 'MON_SCHEMA') loop
          execute immediate 'drop table "'||f.table_name||'" cascade constraints';
        end loop;
        commit;
    end;
    /
    Bonne journée.

  4. #4
    Rédacteur

    Homme Profil pro
    Consultant / formateur Oracle et SQL Server
    Inscrit en
    Décembre 2002
    Messages
    3 460
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Consultant / formateur Oracle et SQL Server

    Informations forums :
    Inscription : Décembre 2002
    Messages : 3 460
    Points : 8 074
    Points
    8 074
    Par défaut
    Citation Envoyé par Juda_ Voir le message
    Comme indiqué par Glutinus il suffit de parcourir les tables du schémas voulu à l'aide d'une boucle et de construire dynamiquement les ordres de suppression des tables.
    Par contre, dans la commande DROP, il faut préfixer le nom de la table par le schéma, sans quoi votre code va tenter de supprimer les tables dans le schéma de celui qui exécute le DROP, ce qui pourrait avoir des effets fâcheux...
    Consultant / formateur Oracle indépendant
    Certifié OCP 12c, 11g, 10g ; sécurité 11g

    Ma dernière formation Oracle 19c publiée sur Linkedin : https://fr.linkedin.com/learning/oracle-19c-l-administration

  5. #5
    Membre à l'essai
    Inscrit en
    Octobre 2011
    Messages
    16
    Détails du profil
    Informations forums :
    Inscription : Octobre 2011
    Messages : 16
    Points : 14
    Points
    14
    Par défaut
    Merci, ça marche beaucoup mieux

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

Discussions similaires

  1. [2005] Comment faire un truncate de toutes les tables d'un schéma ?
    Par clementratel dans le forum SSIS
    Réponses: 12
    Dernier message: 24/03/2011, 10h00
  2. Réponses: 3
    Dernier message: 07/10/2010, 13h12
  3. Count de toutes les tables de tous les schémas
    Par tibal dans le forum PL/SQL
    Réponses: 4
    Dernier message: 21/12/2008, 09h25
  4. Réponses: 3
    Dernier message: 21/08/2008, 18h05
  5. Sélection de toute les tables d'une base
    Par lord_paco dans le forum MS SQL Server
    Réponses: 6
    Dernier message: 21/07/2003, 14h56

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