緣由 解決方法 代碼如下: ...
緣由
因為在某個復(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;