2014-02-11 2 views
1

Для SQL Server 2008 R2 я хочу удалить ограничения по умолчанию для столбцов даты, которые разрешают null, а ограничение содержит 1899. И я хочу, чтобы скрипт мог тестироваться, а затем выполняться в реальном времени. Я не хочу заниматься этим в живой среде. Еще одна причина для сценария является то, что существует несколько баз данных с одной и той же схемеОграничить ограничение по умолчанию в SQL Server на многих столбцах

С помощью Google я следующий сценарий, список столбцов

SELECT tables.name, all_columns.name, all_columns.is_nullable, default_constraints.name, default_constraints.definition 
FROM 
    sys.all_columns 
     INNER JOIN 
    sys.tables 
     ON all_columns.object_id = tables.object_id 
     INNER JOIN 
    sys.schemas 
     ON tables.schema_id = schemas.schema_id 
     INNER JOIN 
    sys.default_constraints 
     ON all_columns.default_object_id = default_constraints.object_id 
WHERE 
     schemas.name = 'dbo' 
    and default_constraints.definition like '%1899%' 
    and all_columns.is_nullable = 1 
order by tables.name, all_columns.name, default_constraints.name 

Теперь этот список более ста колонн. Следующий скрипт делает то, что я хочу для столбца CargoPool.Created. Но как я могу повторить все строки, созданные из моего первого скрипта?

DECLARE @tableName VARCHAR(MAX) = 'CargoPool' 
DECLARE @columnName VARCHAR(MAX) = 'Created' 
DECLARE @ConstraintName nvarchar(200) 
SELECT @ConstraintName = Name 
FROM SYS.DEFAULT_CONSTRAINTS 
WHERE PARENT_OBJECT_ID = OBJECT_ID(@tableName) 
AND PARENT_COLUMN_ID = (
    SELECT column_id FROM sys.columns 
    WHERE NAME = @columnName AND object_id = OBJECT_ID(@tableName)) 
IF @ConstraintName IS NOT NULL 
    EXEC('ALTER TABLE '[email protected]+' DROP CONSTRAINT ' + @ConstraintName) 

ответ

3

Если вы хотите, чтобы удалить все ограничения с вашего первого запроса, вы можете создать динамический SQL с результатами этого запроса, а затем выполнить его:

DECLARE @sql AS NVARCHAR(MAX) = N'' 

SELECT @sql = @sql + N'ALTER TABLE ' 
     + QUOTENAME(schemas.name) + N'.' + QUOTENAME(tables.name) 
     + N' DROP CONSTRAINT ' + QUOTENAME(default_constraints.name) + N'; ' 
FROM 
    sys.all_columns 
     INNER JOIN 
    sys.tables 
     ON all_columns.object_id = tables.object_id 
     INNER JOIN 
    sys.schemas 
     ON tables.schema_id = schemas.schema_id 
     INNER JOIN 
    sys.default_constraints 
     ON all_columns.default_object_id = default_constraints.object_id 
WHERE 
     schemas.name = N'dbo' 
    and default_constraints.definition like N'%1899%' 
    and all_columns.is_nullable = 1 
order by tables.name, all_columns.name, default_constraints.name 

exec sp_executesql @sql; 
+0

+1, но на самом деле должно быть используя NVARCHAR (MAX) и включая схему в команде ALTER TABLE (если есть таблица не в dbo, а в схеме по умолчанию для вызывающего). –

+0

@AaronBertrand Спасибо за комментарии. Я изменил все на «NVARCHAR (MAX)» и добавил схему. – Szymon

Смежные вопросы