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

PL/SQL Oracle Discussion :

Forall : un delete sur des tables variabilisées


Sujet :

PL/SQL Oracle

  1. #1
    Candidat au Club
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Mai 2015
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val d'Oise (Île de France)

    Informations professionnelles :
    Activité : Administrateur de base de données

    Informations forums :
    Inscription : Mai 2015
    Messages : 5
    Points : 4
    Points
    4
    Par défaut Forall : un delete sur des tables variabilisées
    Bonjour tout le monde,

    je n'arrive pas à solutionner mon problème. J'aimerai récolter les infos de noms de table et colonne dans un bulk collect et faire un delete en utilisant le foral.
    J'ai observé qu'il y existe un gain de perf non négligeable avec cette méthode, mais je n'arrive pas à la mettre en place.
    Alors le code sur le delete n'est pas logique, je suis d'accord, mais je n'arrive pas à faire la jointure entre le nom de table de la variable.


    Auriez vous des suggestions svp ?
    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
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
     
    l  DECLARE
     
     TYPE t_table IS TABLE OF liste_table.table%TYPE INDEX BY PLS_INTEGER;
     TYPE t_colonne IS TABLE OF liste_table.colonne%TYPE INDEX BY PLS_INTEGER
     
     
    v_table      t_table;
    v_colonne    t_colonne;
     
    CURSOR c_table IS
              SELECT table, colonne
              FROM   liste_table;
     
           v_cnt   PLS_INTEGER := 0;
     
       BEGIN
     
        OPEN c_table 
          LOOP
            FETCH c_table BULK COLLECT
              INTO v_table      
                   v_colonne    LIMIT 1;          
     
           FORALL i IN v_table.first .. v_table.last 
     
        delete from'||v_table(i)||' where 
                   valeur_colonne = v_colonne(i)
                   ;
     -- Je sais, cela ne va fonctionner mais j'ignore comment la formuler en fait.
             v_cnt := v_cnt + SQL%ROWCOUNT;
     
             EXIT WHEN c_table%NOTFOUND;
     
          END LOOP;
         CLOSE c_table ;
     
          DBMS_OUTPUT.PUT_LINE(TO_CHAR(v_cnt) || ' records deleted.');
     
          COMMIT;
     
       END;
       /

  2. #2
    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
    Il y aurait beaucoup à dire sur votre code, mais un point central, c'est que vous ne pouvez pas faire directement quelque chose comme :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     delete from'||v_table(i)||' where
    En effet, lorsque le nom des tables ou des colonnes n'est connu qu'à l'exécution, il faut utiliser ce qu'on appelle le SQL dynamique.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    execute immediate 'delete from ' || v_table(i) || ' where ...';
    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

  3. #3
    Candidat au Club
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Mai 2015
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val d'Oise (Île de France)

    Informations professionnelles :
    Activité : Administrateur de base de données

    Informations forums :
    Inscription : Mai 2015
    Messages : 5
    Points : 4
    Points
    4
    Par défaut
    Merci Pomalaix pour ta réponse.
    Je vais faire le sql dynamique, je n'ai pas trop le choix .

Discussions similaires

  1. DELETE sur des tables volumineuses
    Par bar_79 dans le forum SAS Base
    Réponses: 2
    Dernier message: 03/12/2012, 11h22
  2. [MSDE] Delete sur plusieurs tables ?
    Par hardballer dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 03/05/2006, 10h13
  3. Statistiques sur des tables
    Par nuke_y dans le forum Oracle
    Réponses: 2
    Dernier message: 24/04/2006, 14h02
  4. delete sur plusieurs tables
    Par drinkmilk dans le forum Oracle
    Réponses: 11
    Dernier message: 22/03/2006, 16h43
  5. [8.0.5-->9.2.0.5] Checksum sur des tables oracle
    Par bobunny dans le forum Oracle
    Réponses: 9
    Dernier message: 24/11/2004, 12h46

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