我需要将 3 个新列添加到所有数据库(同一个实例)中名为 Requirements 的表中。我在网上搜索发现 sp_MSforeachdb 可用于在多个数据库上执行相同的查询,但找不到任何使用 alter 命令的示例。
提前致谢
我需要将 3 个新列添加到所有数据库(同一个实例)中名为 Requirements 的表中。我在网上搜索发现 sp_MSforeachdb 可用于在多个数据库上执行相同的查询,但找不到任何使用 alter 命令的示例。
提前致谢
假设这些表都在同一个模式中,然后使用sp_msforeachdb
EXEC sp_msforeachdb '
IF DB_ID(''?'') > 4
BEGIN
IF EXISTS(SELECT 1 FROM [?].INFORMATION_SCHEMA.TABLES
WHERE TABLE_NAME=''Requirements'' AND TABLE_SCHEMA=''dbo''
AND TABLE_TYPE=''BASE TABLE'')
BEGIN
ALTER TABLE [?].dbo.Requirements
ADD col1 INT, col2 INT, col3 INT
END
END
'
Aaron Bertrand在这里写了一个您可能想要使用的高级版本。
动态sql的另一种方式
DECLARE @sql VARCHAR(MAX) = CAST((SELECT 'IF EXISTS(SELECT 1 FROM [' + name + '].INFORMATION_SCHEMA.TABLES WHERE TABLE_NAME=''Requirements'' AND TABLE_SCHEMA=''dbo'' AND TABLE_TYPE=''BASE TABLE'')' + CHAR(10)
+ ' ALTER TABLE [' + name + '].[dbo].[Requirements] ADD Col1 INT, Col2 INT, Col3 INT' + CHAR(10) + CHAR(10)
FROM master.sys.databases
WHERE database_id > 4
FOR XML PATH('')) AS NVARCHAR(MAX))
PRINT @sql
--EXEC(@sql)
如果您必须考虑表不在dbo
或通用模式中的可能性,那么您可以使用sp_msforeachdb
以下方式检索模式信息
CREATE TABLE ##tmp (DatabaseName SYSNAME, SchemaName SYSNAME, TableName SYSNAME)
EXEC sp_msforeachdb '
IF DB_ID(''?'') > 4
BEGIN
INSERT INTO ##tmp (DatabaseName, SchemaName, TableName)
SELECT TABLE_CATALOG, TABLE_SCHEMA, TABLE_NAME
FROM [?].INFORMATION_SCHEMA.TABLES
WHERE TABLE_NAME = ''Requirements''
AND TABLE_TYPE=''BASE TABLE''
END
'
DECLARE @sql VARCHAR(MAX) = CAST((SELECT 'ALTER TABLE [' + DatabaseName + '].[' + SchemaName + '].[' + TableName + '] ADD Col1 INT, Col2 INT, Col3 INT' + CHAR(10) + CHAR(10)
FROM ##tmp
FOR XML PATH('')) AS NVARCHAR(MAX))
PRINT @sql
--EXEC(@sql)
DROP TABLE ##tmp
以下代码将为每个数据库生成命令:
select 'ALTER TABLE [' + d.name + '].[dbo].[table_name] ADD column_name column-name;' as cmd
from sys.databases d
where d.name NOT IN ( 'tempdb', 'msdb', 'master','model');
您也可以编写一个游标来循环这些并执行它们,但我建议您查看您正在执行的内容并确保您没有更新错误的数据库。
从 mysql 命令行:
ALTER TABLE database1.table_name ADD column_name column-name;
ALTER TABLE database2.table_name ADD column_name column-name;
..