(sql server) requête pour rechercher un {guid} dans tous les champs de toutes les tables d'une base de données

Soyez le premier à donner votre avis sur cette source.

Vue 19 729 fois - Téléchargée 736 fois

Description

Avec cette procédure stockée vous pourrez rechercher un {GUID} dans toutes les colonnes de toutes les tables d'une base de données SQL SERVER. Elle est pratique quand on ne dispose pas de modèle conceptuel de la base.

Source / Exemple :


-- Crée par : L.Attig
-- Date		: 10/2009
-- http://www.etoile-du-sahel.com/
DECLARE @strValeur uniqueidentifier
SET @strValeur = '{0F447BEF-C5BF-DE11-871F-00155D003604}'

IF OBJECT_ID('tempdb..#resultat') IS NOT NULL DROP TABLE #resultat
CREATE TABLE #resultat (TableSchema SYSNAME, TableName SYSNAME);
DECLARE @sql NVARCHAR(MAX);
WITH cte_all_tables(SQL) AS (
    SELECT
          N' INSERT #resultat (TableSchema, TableName)'
        + N' SELECT ''' + t.TABLE_SCHEMA + ''', ''' + t.TABLE_NAME + N'''' 
        + N' FROM ' + QUOTENAME(t.TABLE_SCHEMA) + '.' +QUOTENAME(t.TABLE_NAME)
        + N' WHERE ' +
        (
                SELECT QUOTENAME(c.COLUMN_NAME) + N' = @strValeur OR '
                FROM INFORMATION_SCHEMA.Columns c
                WHERE c.TABLE_NAME = t.TABLE_NAME
                        AND c.TABLE_SCHEMA = t.TABLE_SCHEMA
                        AND c.DATA_TYPE = 'uniqueidentifier'
                FOR XML PATH('')
        ) + N'0=1'
   FROM INFORMATION_SCHEMA.Columns c
        INNER JOIN INFORMATION_SCHEMA.Tables t
        ON c.TABLE_NAME = t.TABLE_NAME
        AND t.TABLE_SCHEMA = c.TABLE_SCHEMA
        AND t.TABLE_TYPE = 'BASE TABLE'
    WHERE DATA_TYPE = 'uniqueidentifier')
SELECT @sql = (SELECT [SQL]+nchar(10) FROM cte_all_tables FOR XML PATH(''));

PRINT @SQL;
exec sp_executesql @sql, N'@strValeur uniqueidentifier', @strValeur;

-- Retourne la liste des tables
SELECT distinct(Tablename) FROM #resultat

Conclusion :


Enjoy ...

Codes Sources

A voir également

Ajouter un commentaire

Commentaires

Commenter la réponse de cs_Delphiprog

Vous n'êtes pas encore membre ?

inscrivez-vous, c'est gratuit et ça prend moins d'une minute !

Les membres obtiennent plus de réponses que les utilisateurs anonymes.

Le fait d'être membre vous permet d'avoir un suivi détaillé de vos demandes et codes sources.

Le fait d'être membre vous permet d'avoir des options supplémentaires.