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

MS SQL Server Discussion :

[SQL2K]Récupérer les vues qui font référence au champ d'une table


Sujet :

MS SQL Server

  1. #1
    Membre régulier
    Inscrit en
    Octobre 2004
    Messages
    110
    Détails du profil
    Informations forums :
    Inscription : Octobre 2004
    Messages : 110
    Points : 77
    Points
    77
    Par défaut [SQL2K]Récupérer les vues qui font référence au champ d'une table
    Bonjour à tous ,

    Je voudrais récupérer la liste exhaustive des vues
    qui font référence à un champ particulier d'une table .
    Je précise que j'ai des vues qui appellent d'autres vues , il faut donc que
    la requête puisse remonter jusqu'à la table d'où est issu le champ recherché.

    Comment puis-je faire une telle requête ?

    Merci d'avance

    Jean-Yves

  2. #2
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 865
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 21 865
    Points : 53 018
    Points
    53 018
    Billets dans le blog
    6
    Par défaut
    déjà répondu sur forum MS

    En sus pour les vues de vues, il s'agit d'utiliser une requête CTE récursive.

    A +

  3. #3
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 865
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 21 865
    Points : 53 018
    Points
    53 018
    Billets dans le blog
    6
    Par défaut
    Après m'être penché davantage sur votre intéressant problème voici la requête adéquate :

    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
    WITH V_VIEWS (VIEW_SCHEMA, VIEW_NAME, VIEW_DEFINITION, VIEW_LEVEL)
    AS
    (
    -- views having a column nammed STE_TVA_CODE_PAYS
    SELECT TABLE_SCHEMA AS VIEW_SCHEMA,
           TABLE_NAME AS VIEW_NAME, 
           VIEW_DEFINITION,
           0 AS VIEW_LEVEL
    FROM   INFORMATION_SCHEMA.VIEWS
    WHERE  VIEW_DEFINITION LIKE '%STE_TVA_CODE_PAYS%'
    UNION ALL
    -- views having a view based on a column nammed STE_TVA_CODE_PAYS
    SELECT V1.TABLE_SCHEMA AS VIEW_SCHEMA,
           V1.TABLE_NAME AS VIEW_NAME, 
           V1.VIEW_DEFINITION,
           V2.VIEW_LEVEL + 1
    FROM   INFORMATION_SCHEMA.VIEWS V1
           INNER JOIN V_VIEWS V2
                 ON V1.VIEW_DEFINITION 
                    LIKE '%' + V2.VIEW_SCHEMA + '.' + V2.VIEW_NAME + '%'
    WHERE  V2.VIEW_DEFINITION LIKE '%STE_TVA_CODE_PAYS%'
      AND  V2.VIEW_SCHEMA + '.' + V2.VIEW_NAME <> V1.TABLE_SCHEMA + '.' + V1.TABLE_NAME
    )
    SELECT *
    FROM   V_VIEWS
    Ici on recherche les vues ayant une colonne de nom STE_TVA_CODE_PAYS.
    Le résultat donne les vues de niveau zéro (celles ayant directement la colonnes), puis les vues de niveau 1 (faisant référence à une vue de niveau 0), 2 (aisant référence à une vue de niveau 1), etc.

    La requête utilise une CTE (Commaon table expression qui permet des requêtes récursive.
    Si vous êtes pas enc version 2005, il faut faire cela avec des requêtes succesives comme ceci :

    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
    -- views having a column nammed STE_TVA_CODE_PAYS
    SELECT TABLE_SCHEMA AS VIEW_SCHEMA,
           TABLE_NAME AS VIEW_NAME, 
           0 AS VIEW_LEVEL
    FROM   INFORMATION_SCHEMA.VIEWS
    WHERE  VIEW_DEFINITION LIKE '%STE_TVA_CODE_PAYS%'
     
    -- views having a view based on a column nammed STE_TVA_CODE_PAYS
    SELECT V1.TABLE_SCHEMA AS VIEW_SCHEMA,
           V1.TABLE_NAME AS VIEW_NAME, 
           1 AS VIEW_LEVEL
    FROM   INFORMATION_SCHEMA.VIEWS V1
           INNER JOIN INFORMATION_SCHEMA.VIEWS V2
                 ON V1.VIEW_DEFINITION 
                    LIKE '%' + V2.TABLE_SCHEMA + '.' + V2.TABLE_NAME + '%'
    WHERE  V2.VIEW_DEFINITION LIKE '%STE_TVA_CODE_PAYS%'
      AND  V2.TABLE_SCHEMA + '.' + V2.TABLE_NAME <> V1.TABLE_SCHEMA + '.' + V1.TABLE_NAME

    A +

  4. #4
    Membre régulier
    Inscrit en
    Octobre 2004
    Messages
    110
    Détails du profil
    Informations forums :
    Inscription : Octobre 2004
    Messages : 110
    Points : 77
    Points
    77
    Par défaut
    Merci bien Frédéric , j'ai compris le système.

    Jean-Yves

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

Discussions similaires

  1. Réponses: 0
    Dernier message: 20/11/2013, 11h01
  2. ajouter les items d'un listbox à un champ d'une table
    Par salim2020 dans le forum VB 6 et antérieur
    Réponses: 3
    Dernier message: 02/04/2010, 22h29
  3. Réponses: 5
    Dernier message: 12/10/2009, 14h32
  4. Réponses: 2
    Dernier message: 26/07/2007, 14h27
  5. Référence à un champ ds une table sans l'ouvrir
    Par electrosat03 dans le forum Access
    Réponses: 4
    Dernier message: 12/02/2006, 22h58

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