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

Langage SQL Discussion :

optimisation delete requete


Sujet :

Langage SQL

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    358
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 358
    Points : 117
    Points
    117
    Par défaut optimisation delete requete
    Bonjour,

    J'ai un petit souci avec des requetes delete.

    J'en ai 30.

    Le delete se sert d'un select pour supprimer les données. Or ce select est identique pour toutes les requete.

    En gros, j'ai

    delete from table1 where table1.id in (select id from toto)
    delete from table2 where table2.id in (select id from toto)
    delete from table3 where table3.id in (select id from toto)
    etc....
    etc..

    J'aimerai pouvoir charger une seule fois le select id from toto et utiliser ces valeurs pour chaque delete.

    J'ai réfléchi à 2 solutions :
    la première : utiliser la clause with, mais cette clause est utilisé que pour une seule requete et non pour plusieurs, elle ne sauvegarde pas le résultat pour toutes les requetes.

    La seconde : créer un cursor, et faire un :
    delete from table1 where table1.id = cursor.get(0)
    delete from table2 where table2.id = cursor.get(0)

    Je parcours chaque id, et je supprime de toutes les tables, mais je sais pas si cela est optimisé....

    Sinon je fais chaque delete en rechargeant à chaque fois ma requete select.

    Je sais pas quoi faire ?

    merci

  2. #2
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Sr. Specialist Solutions Architect @Databricks
    Inscrit en
    Septembre 2008
    Messages
    8 453
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Sr. Specialist Solutions Architect @Databricks
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 453
    Points : 18 388
    Points
    18 388
    Par défaut
    Non votre solution actuelle reste la meilleure :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    delete from table1 where table1.id in (select id from toto)
    delete from table2 where table2.id in (select id from toto)
    delete from table3 where table3.id in (select id from toto)
    Néamoins il me semble que vous avez beaucoup de sujets sur différents morceaux du même problème, je vous encourage à détailler toutes les étapes de votre process point par point, avec les volumétries et les temps impliqués, et tant qu'à faire postez le tout dans le forum Oracle

Discussions similaires

  1. Optimisation de requete
    Par Scorff dans le forum MS SQL Server
    Réponses: 8
    Dernier message: 11/07/2005, 09h59
  2. [sgbd]Optimisation des requetes Oracle/Perl
    Par linou dans le forum SGBD
    Réponses: 7
    Dernier message: 30/06/2005, 18h09
  3. Optimiser une Requetes SQL sous ASP
    Par NeHuS dans le forum ASP
    Réponses: 8
    Dernier message: 18/04/2005, 16h26
  4. Optimisation de requete
    Par cyril dans le forum SQL
    Réponses: 3
    Dernier message: 09/10/2003, 08h57
  5. Optimisation des requetes
    Par bifidus dans le forum MS SQL Server
    Réponses: 5
    Dernier message: 06/10/2003, 11h29

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