繁体   English   中英

sql - 将列(表之一的外键)添加到数据库中的所有表

[英]sql - Add column(foreign key to one of the table) to all tables in databases

我正在尝试向 db 中的所有表添加一个新列,这是其中一个表的外键。 理想情况下,我应该将该列添加到所有表而不是外键引用的表。

如何将这两个 SQL 语句组合为一个语句?

// Get all tables except the foreign key reference to
SELECT * 
FROM INFORMATION_SCHEMA.TABLES
WHERE TABLE_SCHEMA="arthurMurray"
AND TABLE_TYPE="BASE TABLE"
AND TABLE_NAME!="Competitions";

// Add compeition_id to table as a foreign key to competitions table
ALTER TABLE t
ADD competition_id INTEGER,
ADD CONSTRAINT FOREIGN KEY(competition_id) REFERENCES Competitions(id);

任何帮助将不胜感激!

请检查这个

EXEC sp_MSforeachtable '
if not exists (select * from sys.columns 
               where object_id = object_id(''?'')
               and name = ''CreatedOn'') 
begin
    ALTER TABLE ? ADD CreatedOn datetime NOT NULL DEFAULT getdate();
end';

你可以使用下面的查询来生成你的alter语句,然后你可以复制粘贴并执行下面的脚本。

SELECT 
  'ALTER TABLE ' +  TABLE_NAME + 'ADD competition_id INTEGER,  ADD CONSTRAINT FOREIGN KEY(competition_id) REFERENCES Competitions(id);'
FROM INFORMATION_SCHEMA.TABLES
WHERE TABLE_SCHEMA='whatever_schema'
  AND TABLE_TYPE='BASE TABLE'
  AND TABLE_NAME!='Competitions';

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM