DWH-ETL-OLAP
October 8, 2019
Изменение Collation для всех столбцов всех таблиц БД
Если для БД изменить Collation не так сложно вручную через SSMS, то для каждого столбца придется писать дополнительный отдельный запрос, тк изменения collation для БД не означает автоматическое изменения этого параметра для каждого столбца.
Здесь поможет вот этот скриптик:
DECLARE @collate nvarchar(100); DECLARE @table nvarchar(255); DECLARE @column_name nvarchar(255); DECLARE @column_id int; DECLARE @data_type nvarchar(255); DECLARE @max_length int; DECLARE @row_id int; DECLARE @sql nvarchar(max); DECLARE @sql_column nvarchar(max);
SET @collate = 'SQL_Latin1_General_CP1251_CI_AS';
DECLARE local_table_cursor CURSOR FOR
SELECT SCHEMA_NAME(o.schema_id) +'.'+ so.[name] FROM sysobjects so join sys.objects o on o.object_id = so.id WHERE OBJECTPROPERTY(id, N'IsUserTable') = 1
OPEN local_table_cursor FETCH NEXT FROM local_table_cursor INTO @table
WHILE @@FETCH_STATUS = 0 BEGIN
DECLARE local_change_cursor CURSOR FOR
SELECT ROW_NUMBER() OVER (ORDER BY ORDINAL_POSITION) AS row_id
,COLUMN_NAME column_name
,data_type
,CHARACTER_MAXIMUM_LENGTH max_length
,ORDINAL_POSITION column_id
from INFORMATION_SCHEMA.COLUMNS
WHERE TABLE_SCHEMA + '.' + TAble_NAme = @table
ORDER BY ORDINAL_POSITION OPEN local_change_cursor
FETCH NEXT FROM local_change_cursor
INTO @row_id, @column_name, @data_type, @max_length, @column_id WHILE @@FETCH_STATUS = 0
BEGINIF (@max_length = -1) OR (@max_length > 4000) SET @max_length = 4000;
IF (@data_type LIKE '%char%')
BEGIN TRY
SET @sql = 'ALTER TABLE ' + @table + ' ALTER COLUMN ' + @column_name + ' ' + @data_type + '(' + CAST(@max_length AS nvarchar(100)) + ') COLLATE ' + @collate
PRINT @sql
EXEC sp_executesql @sql
END TRY
BEGIN CATCH
PRINT 'ERROR: Some index or constraint rely on the column' + @column_name + '. No conversion possible.'
PRINT @sql
END CATCH FETCH NEXT FROM local_change_cursor
INTO @row_id, @column_name, @data_type, @max_length, @column_idEND
CLOSE local_change_cursor
DEALLOCATE local_change_cursor FETCH NEXT FROM local_table_cursor
INTO @tableEND
CLOSE local_table_cursor DEALLOCATE local_table_cursor
GO