1

我有两张表,我想合并。但是,两个表中都有一个字段应该在第二个表中具有相同的值,第二个表记录应该被排除。

这些是 MSSQL 2012 表。

我能想到的唯一方法就是像这样讨厌的东西。

Select A, B from Tab1 Union Select C, D from Tab2 where Tab2.c not in (Select A from Tab1)

在我的示例中它看起来相对干净,但 Tab1 和 tab2 的选择具有长而复杂的 where 子句,我需要在“不在”选择语句中复制它。

我见过其他解决方案,但在 MSSQL 中没有。有没有人有更好的例子?

谢谢

4

1 回答 1

0

在 t-sql 中我使用这种代码

USE tempdb
GO
CREATE TABLE StudentDetails
(
StudentID INTEGER PRIMARY KEY,
StudentName VARCHAR(15)
)
GO
INSERT INTO StudentDetails
VALUES(1,'SMITH')
INSERT INTO StudentDetails
VALUES(2,'ALLEN')
INSERT INTO StudentDetails
VALUES(3,'JONES')
INSERT INTO StudentDetails
VALUES(4,'MARTIN')
INSERT INTO StudentDetails
VALUES(5,'JAMES')
GO
CREATE TABLE StudentTotalMarks
(
StudentID INTEGER REFERENCES StudentDetails,
StudentMarks INTEGER
)
GO
INSERT INTO StudentTotalMarks
VALUES(1,230)
INSERT INTO StudentTotalMarks
VALUES(2,255)
INSERT INTO StudentTotalMarks
VALUES(3,200)
GO
-- Select from Table
SELECT *
FROM StudentDetails
GO
SELECT *
FROM StudentTotalMarks
GO
-- Merge Statement
MERGE StudentTotalMarks AS stm
USING (SELECT StudentID,StudentName FROM StudentDetails) AS sd
ON stm.StudentID = sd.StudentID
WHEN MATCHED AND stm.StudentMarks > 250 THEN DELETE
WHEN MATCHED THEN UPDATE SET stm.StudentMarks = stm.StudentMarks + 25
WHEN NOT MATCHED THEN
INSERT(StudentID,StudentMarks)
VALUES(sd.StudentID,25);
GO
-- Select from Table
SELECT *
FROM StudentDetails
GO
SELECT *
FROM StudentTotalMarks
GO
-- Clean up
DROP TABLE StudentDetails
GO
DROP TABLE StudentTotalMarks
GO

Merge Join 的表现非常好,得到如下结果。 http://www.pinaldave.com/bimg/MergeStatement.gif

希望这可以帮助

于 2013-08-22T02:52:09.130 回答