intersect 运算符用于查找两个或多个表的公共行,即同时在所有表中出现的行。用法如下:每个 select 语句指定要比较的列列表。intersect 比较相对应列值,如果所有值都相等,则包含该行。可使用 union 子句将结果与其他表的 intersect 结果组合。
Oracle 中 INTERSECT 用法
INTERSECT 运算符用于查找两个或多个表的公共行,即同时在所有表中出现的行。它是一种集合运算,检索出满足特定条件的行。
语法:
SELECT column_list
FROM table1
INTERSECT
SELECT column_list
FROM table2
[UNION]
SELECT column_list
FROM table3 ...;
用法说明:
- INTERSECT 运算符将比较来自不同表的行的相对应列值。
- 如果所有行的值对于给定的列都相等,那么该行将被包含在结果集中。
- UNION 子句可用于将结果集与其他表的 INTERSECT 结果组合在一起。
- 列列表必须在所有 SELECT 语句中相同。
示例:
假设我们有以下两个表:
Table1:
ID | Name |
---|---|
1 | John |
2 | Mary |
3 | Bob |
Table2:
ID | Address |
---|---|
1 | 123 Main St |
2 | 456 Oak Ave |
3 | 789 Pine St |
查询:
SELECT ID, Name, Address
FROM Table1
INTERSECT
SELECT ID, NULL, Address
FROM Table2;
结果:
ID | Name | Address |
---|---|---|
1 | John | 123 Main St |
2 | Mary | 456 Oak Ave |
在这个例子中,INTERSECT 运算符返回了在 Table1 和 Table2 中都具有相同 ID 值的行。
以上就是oracle中intersect的用法的详细内容,更多请关注编程网其它相关文章!