SQL SERVER 如何取三张表得交集
时间: 2024-09-24 11:03:03 浏览: 40
SQL Server删除表及删除表中数据的方法
在SQL Server中,如果你想要从三张表中获取它们的交集,也就是找出在这三张表中共有的记录,你可以使用`INNER JOIN`操作结合`WHERE`子句来实现。这里是一个基本的示例:
```sql
SELECT T1.column1, T2.column2, T3.column3
FROM Table1 AS T1
JOIN Table2 AS T2 ON T1.common_column = T2.common_column
JOIN Table3 AS T3 ON T2.common_column = T3.common_column
```
在这个例子中,`Table1`, `Table2`, 和 `Table3` 是你要连接的三张表,`common_column` 是这三张表共享的列名,用于找到它们之间的关联。结果将只包含同时在所有三张表中存在的行。
如果你需要进一步限制结果,可以在`ON`后面的条件中添加额外的过滤条件。如果想要得到完全相等的交集,可以考虑使用子查询,先分别计算每两张表的交集,然后再做第二次的交集:
```sql
WITH Intersect1 AS (
SELECT * FROM Table1
JOIN Table2 ON Table1.common_column = Table2.common_column
),
Intersect2 AS (
SELECT * FROM Intersect1
JOIN Table3 ON Intersect1.common_column = Table3.common_column
)
SELECT *
FROM Intersect2;
```
阅读全文