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

Développement SQL Server Discussion :

Epuration de table.


Sujet :

Développement SQL Server

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Décembre 2002
    Messages
    120
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2002
    Messages : 120
    Points : 69
    Points
    69
    Par défaut Epuration de table.
    * Bonjour, *

    Voila ma question :
    J'ai une table X qui peut être liées par Foreign Key à d'autres tables (mais je ne les connait pas forcément) et je souhaite épurer la table donc supprimer tous les enregistrements non utilisés ailleurs ...

    Je procède actuellement de la sorte :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    CURSOR C FOR SELECT CLE FROM MATABLE
    Parcours du curseur C
      BEGIN TRY
         DELETE FROM MATABLE WHERE CURRENT OF C
      END TRY
      BEGIN CATCH
        --
      END CATCH
    ...
    Mais sur des tables de près de 10000 enreg cela est très long : Avez vous un autre moyen ?

    * Merci *

  2. #2
    Membre émérite

    Homme Profil pro
    Chargé de Développement et d'Analyse de données
    Inscrit en
    Mars 2010
    Messages
    1 278
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Chargé de Développement et d'Analyse de données
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mars 2010
    Messages : 1 278
    Points : 2 856
    Points
    2 856
    Par défaut
    Citation Envoyé par scornille Voir le message
    Voila ma question :
    J'ai une table X qui peut être liées par Foreign Key à d'autres tables (mais je ne les connait pas forcément) et je souhaite épurer la table donc supprimer tous les enregistrements non utilisés ailleurs ...
    Mais sur des tables de près de 10000 enreg cela est très long : Avez vous un autre moyen ?
    Installe le logiciel SQLExecMS .

    Ce logiciel te permet d'avoir de la visibilité sur toutes les tables liées à ta table X et les tables dont X dépend.

    A+
    Etienne ZINZINDOHOUE
    Billets-Articles

  3. #3
    Expert éminent sénior
    Avatar de mikedavem
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Août 2005
    Messages
    5 450
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Ain (Rhône Alpes)

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

    Informations forums :
    Inscription : Août 2005
    Messages : 5 450
    Points : 12 891
    Points
    12 891
    Par défaut
    Bonsoir,

    Il est possible d'utiliser TSQL pour avoir la liste des tables dépendantes à la votre.

    Par exemple :

    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
    WITH H ([level], [object], object_parent)
    AS
    (
    	SELECT 
    	    0,
    		OP.name AS object,
    		O.name AS object_parent
    	FROM sys.foreign_keys AS FL
    	INNER JOIN sysobjects AS O
    	 ON O.id = FL.referenced_object_id
    	INNER JOIN sysobjects AS OP
    	 ON FL.parent_object_id = OP.id
    	 WHERE O.name = '<maTable>'
    	 UNION ALL
    	 SELECT 
    	    H.level + 1,
    		OP.name,
    		H.object
    	FROM sys.foreign_keys AS FL
    	INNER JOIN sysobjects AS O
    	 ON O.id = FL.referenced_object_id
    	INNER JOIN sysobjects AS OP
    	 ON FL.parent_object_id = OP.id
    	INNER JOIN H
    	 ON O.name = H.[object]
     )
     SELECT *
     FROM H
     ORDER BY [level] DESC;
    Pourquoi supprimez vous les enregistrements un à un dans votre table ? Ceci est contre performant ...

    ++

  4. #4
    Membre du Club
    Profil pro
    Inscrit en
    Décembre 2002
    Messages
    120
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2002
    Messages : 120
    Points : 69
    Points
    69
    Par défaut
    Justement comment épurer la table autrement si j'ai 7 foreign Keys liées à cette table la requête générée en faisant toutes les liaisons serait à mon avis encore plus longue ... Sachant que ce sera un delete from xxx where clé not in (select clé from yyy union ...........).

    C'est justement l'objet de la question ...

    En fait le problème c'est que le delete d'un enreg lorsqu'une foreign key existe est très long à cause des vérifications de contraintes ...

  5. #5
    Membre éprouvé
    Profil pro
    Inscrit en
    Juin 2007
    Messages
    1 056
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2007
    Messages : 1 056
    Points : 1 216
    Points
    1 216
    Par défaut
    tu peux prendre le pb à l'envers :

    tu crées une réplique de ta table.

    - pour chaque FK, j'insère la PK des lignes ayant une correspondance dans les tables sous jacentes Donc tu as au final une table temporaire qui contient tous les lignes qui ont une correspondance avec au moins une FK.

    - tu supprime ta table d'origine et renomme cette table.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    create table matable2 (CLE int)
     
    insert into matable2 
    select CLE FROM MATABLE where fk1 in (select cle from tablefk1)
    union
    select CLE FROM MATABLE where fk2 in (select cle from tablefk2)
    etc....
     
    drop table MATABLE 
     
    sp_rename matable2 , MATABLE
    tu peux même utiliser SELECT INTO si ta base est en mode de récup SIMPLE pour générer le moins de journal possible, ce qui accélèrera ton traitement.
    Emmanuel T.

Discussions similaires

  1. Epurer une table mysql
    Par orangepulpe dans le forum Requêtes
    Réponses: 1
    Dernier message: 21/02/2012, 15h40
  2. Réparation table/entête endommagée
    Par tbesrour dans le forum Paradox
    Réponses: 15
    Dernier message: 27/11/2007, 11h42
  3. [ADO] Tester l'existence d'une table
    Par nd25 dans le forum VB 6 et antérieur
    Réponses: 11
    Dernier message: 05/09/2002, 14h55
  4. Newbie......compilateur et table de caractères
    Par Cyberf dans le forum Autres éditeurs
    Réponses: 1
    Dernier message: 21/08/2002, 15h29
  5. [Comparatifs] Limites nombres tables et quantité de données
    Par benj63 dans le forum Décisions SGBD
    Réponses: 7
    Dernier message: 13/06/2002, 22h31

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