sql >> Database >  >> RDS >> Sqlserver

Genereer CREATE-scripts voor een lijst met indexen

Je bent redelijk dichtbij, zou ik zeggen - ik heb dit geprobeerd, kun je controleren of dit voor jou werkt en je de verwachte 122 indices laat zien die opnieuw moeten worden gemaakt??

UPDATE :functionaliteit toegevoegd om CLUSTERED vs. NONCLUSTERED indextype te bepalen, en INBEGREPEN kolommen toe te voegen aan de indexdefinitie.

WITH indexCTE AS
(
    SELECT DISTINCT 
        i.index_id, i.name, i.object_id
    FROM 
        sys.indexes i 
    INNER JOIN
        sys.index_columns ic 
           ON i.index_id = ic.index_id AND i.object_id = ic.object_id
    WHERE 
        EXISTS (SELECT * FROM sys.columns c 
                 WHERE c.collation_name = 'Modern_Spanish_CI_AS' 
                 AND c.column_id = ic.column_id AND c.object_id = ic.object_id)
), 
indexCTE2 AS
(
    SELECT 
        indexCTE.name 'IndexName', 
        OBJECT_NAME(indexCTE.object_ID) 'TableName',
        CASE indexCTE.index_id 
          WHEN 1 THEN 'CLUSTERED'
          ELSE 'NONCLUSTERED'
        END AS 'IndexType', 
        (SELECT DISTINCT c.name + ','
         FROM 
            sys.columns c 
         INNER JOIN
            sys.index_columns ic 
               ON c.object_id = ic.object_id AND ic.column_id = c.column_id AND ic.Is_Included_Column = 0
         WHERE
            indexCTE.OBJECT_ID = ic.object_id 
            AND indexCTE.index_id = ic.index_id 
         FOR XML PATH('')
        ) ixcols,
        ISNULL(
        (SELECT DISTINCT c.name + ','
         FROM 
            sys.columns c 
         INNER JOIN
            sys.index_columns ic 
               ON c.object_id = ic.object_id AND ic.column_id = c.column_id AND ic.Is_Included_Column = 1
         WHERE
            indexCTE.OBJECT_ID = ic.object_id 
            AND indexCTE.index_id = ic.index_id 
         FOR XML PATH('')
        ), '') includedcols
    FROM 
        indexCTE
) 
SELECT 
    'CREATE ' + IndexType + ' INDEX ' + IndexName + ' ON ' + TableName + 
        '(' + SUBSTRING(ixcols, 1, LEN(ixcols)-1) + 
        CASE LEN(includedcols)
          WHEN 0 THEN ')'
          ELSE ') INCLUDE (' + SUBSTRING(includedcols, 1, LEN(includedcols)-1) + ')'
        END
FROM 
   indexCTE2
ORDER BY 
   TableName, IndexName

Krijg je de CREATE INDEX verklaringen waarnaar u op zoek bent??

Marc



  1. Wat is het verschil tussen SERIAL en AUTO_INCREMENT in mysql

  2. De uitdaging zit erop! Community-oproep voor het maken van de snelste nummerreeksgenerator

  3. Oracle:DBMS_UTILITY.EXEC_DDL_STATEMENT versus IMMEDIATE UITVOEREN

  4. SELECT * of SELECT specifieke kolommen