我试过寻找这个问题的答案,但无济于事。这种设置方式背后没有很好的逻辑。这家伙不知道他在做什么,但这是我必须与之合作的(长话短说)。
我正在使用 SQL Server 2008R2 我需要从一个表中获取记录并将数据传输到 4 个单独的表中,所有表都具有一对一的关系(我知道 - 不聪明)。我需要从插入数据的第一个表中的 Identity 字段中获取值,然后用相同的 ID 填充其他 3 个表并相应地分散数据。例如:
旧表:字段 1、字段 2、字段 3、字段 4
NewTable1:标识字段,Field1 NewTable2:ID,Field2 NewTable3:ID,Field3 NewTable4:ID,Field4
我想在存储过程中处理这个问题。我想做一个循环,但我读到 SQL 中的循环是不可取的。
Loop moving through each record in OldTable... (??)
INSERT INTO NewTable1
(Field1)
Select Field1 from OldTable
INSERT INTO NewTable2
(ID, Field2)
Select SCOPE_IDENTITY?, Field2 From OldTable Where OldTable.ID = ??
etc for other 2 tables
Loop to next record in OldTable
我不确定如何使用 SCOPE_IDENTITY,但我感觉这将涉及我如何完成此任务。
此外,每当在 NewTable1 中创建新记录时,我可能需要设置一个触发器。我知道,这很疯狂,但我对此无能为力,只能解决它。
所以,我需要知道 1:最初填充表的最佳方法 2:如何为新记录创建触发器
1 的解决方案可能涉及 2。
请帮忙!