Tabela INSERT ou UPDATE de outra tabela com chave primária composta
Eu estou procurando a sintaxe correta e maneira de fazer o seguinte diretamente do SQL: inserir ou atualizar (se os dados já existirem dentro)TableMain
de dados contidos emTableA
com ambos tendo a mesma chave primária composta.
Ambas as tabelas são definidas como:
CREATE TABLE TableA (
[TID0] [int] NOT NULL,
[TID1] [int] NOT NULL,
[language] [nvarchar](2) NOT NULL,
[TID2] [nvarchar](200) NOT NULL,
[text] [nvarchar](max) NULL,
[updatedOn] [datetime] NOT NULL DEFAULT (getdate())
PRIMARY KEY (
[TID0],
[TID1],
[language],
[TID2],
)
) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]
TableA
será periodicamente excluído e preenchido.
TableMain
como a mesma definição, mas irá conter muitas mais linhas de dados e o que eu preciso é inserir valores nunca vistos deTableA
para dentroTableMain
e atualize as linhas já existentes.
Eu costumava fazer este tipo de inserção, mas eu não sei como lidar com chaves primárias de atualização e composição:
INSERT INTO TableMain
SELECT * FROM TableA
EDIT: eu estou usandoSQL Server 9.00.5000
EDIT: outra maneira inspirada por MERGE eimita
DECLARE @updatedIDs TABLE(
[TID0] [int],
[TID1] [int],
[language] [nvarchar](2),
[TID2] [nvarchar](200),
PRIMARY KEY ([TID0], [TID1], [language], [TID2]) -- as stated by Nikola Markovinović above, thanks
);
-- First update records
update TableMain
set [text] = source.[text],
[updatedOn] = source.[updatedOn]
OUTPUT
inserted.[TID0]
inserted.[TID1]
inserted.[language]
inserted.[TID2]
INTO @updatedIDs
from
TableMain AS main
, TableA AS source
WHERE
TableMain.[TID0] = source.[TID0]
and TableMain.[TID1] = source.[TID1]
and TableMain.[language] = source.[language]
and TableMain.[TID2] = source.[TID2]
-- And then insert
insert into TableMain
select *
from TableA AS source
where not exists
(
select 1
from @updatedIDs AS i
where i.[TID0] = source.[TID0]
and i.[TID1] = source.[TID1]
and i.[language] = source.[language]
and i.[TID2] = source.[TID2]
)