Для 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)
+1, но на самом деле должно быть используя NVARCHAR (MAX) и включая схему в команде ALTER TABLE (если есть таблица не в dbo, а в схеме по умолчанию для вызывающего). –
@AaronBertrand Спасибо за комментарии. Я изменил все на «NVARCHAR (MAX)» и добавил схему. – Szymon