SqlServer中迴圈給多張表建立聚簇索引
阿新 • • 發佈:2019-01-12
緣由
因為在某個復(bian)雜(tai)需求中用到了170+張表進行查詢,而且表中的資料過多,查起來緩慢。只能給這些表新增索引。
但是,連表名也是無法確定的(無力吐槽)。
解決方法
使用遊標遍歷查詢出來的符合條件的表名,通過拼接sql語句進行建立索引。
程式碼如下:
--宣告變數
DECLARE
@tableName AS VARCHAR(50) = '',
@SqlStr AS VARCHAR(MAX) = '';
--宣告遊標
DECLARE C_TableName CURSOR FAST_FORWARD FOR (
select name from sysobjects where xtype='u' AND name LIKE 'EAR%2019' --讀取庫中的所有表名
);
OPEN C_TableName;
--取第一條記錄
FETCH NEXT FROM C_TableName INTO @tableName;
WHILE @@FETCH_STATUS = 0
BEGIN
--組裝sql語句
SET @SqlStr = 'CREATE INDEX ' + @tableName + '_called_duration' + ' ON ' + @tableName + '(called,duration);';
EXEC (@SqlStr);
PRINT @SqlStr;
--取下一條記錄
FETCH NEXT FROM C_TableName INTO @tableName;
END
-- 關閉遊標
CLOSE C_TableName;
-- 釋放遊標
DEALLOCATE C_TableName;