In Oracle, INTERSECT Operator is used to return the results of 2 or more SELECT statement. It picks the common or intersecting records from compound SELECT queries.
Syntax
SELECT expression1, expression2, ... expression_n
FROM table1
WHERE conditions
INTERSECT
SELECT expression1, expression2, ... expression_n
FROM table2
WHERE conditions;
Parameters
1) expression1, expression2, … expression_n: It specifies the columns that you want to retrieve.
2) table1, table2: It specifies the tables that you want to retrieve records from.
3) conditions: it specifies the conditions that must be fulfilled for the records to be selected.
Oracle INTERSECT Example: (with single expression)
Suppliers Table
data:image/s3,"s3://crabby-images/12b27/12b275e44d331a02cb3d2984bf5cdee8a95611b0" alt="Oracle Intersect 1"
Suppliers Data
data:image/s3,"s3://crabby-images/b62de/b62de1edfb54b3ebed23c2f9cfb7a4368b9ded46" alt="Oracle Intersect 2"
Order_details Table
data:image/s3,"s3://crabby-images/bbdf5/bbdf5040510af30f7a003b12aa72ba55d4d2a7f3" alt="Oracle Intersect 3"
Order_details Data
data:image/s3,"s3://crabby-images/f389d/f389d086a9efef6c825a6778c60481deabf4f703" alt="Oracle Intersect 4"
SELECT supplier_id
FROM suppliers
INTERSECT
SELECT supplier_id
FROM order_details;
In the above example, the supplier_id appears in both the suppliers and order_details table. Now the common entries will be returned in the result set.
Output
data:image/s3,"s3://crabby-images/35a26/35a265ce48a0e1e2e0cc3466f9fced5ffa7c1cb0" alt="Oracle Intersect"
Oracle INTERSECT Example: (with multiple expressions)
Supplier Table
data:image/s3,"s3://crabby-images/95fcd/95fcd29a5e22d1ce2b9f6873538c277dd69e27b8" alt="Oracle Intersect 5"
Supplier Data
data:image/s3,"s3://crabby-images/b24d2/b24d22bbbfeb264151367137d783b8275f4e8d91" alt="Oracle Intersect 6"
Customer Table
data:image/s3,"s3://crabby-images/a53d4/a53d430ccd1d76eea6d82f2fa65e29cf89d228d6" alt="Oracle Intersect 7"
Customer Data
data:image/s3,"s3://crabby-images/8c1ef/8c1ef4cdd77f6c5d5cbee43448efb9b306daabe6" alt="Oracle Intersect 8"
SELECT supplier_id, last_name, first_name
FROM supplier
WHERE first_name <> 'dhirubhai'
INTERSECT
SELECT customer_id, last_name, first_name
FROM customer
WHERE customer_id < 5;
Output
data:image/s3,"s3://crabby-images/4528a/4528afd4bcefd57a0ae30235f9b9e861b3048bc5" alt="Oracle Intersect 9"
The above example returns the records from the supplier table where the supplier_id, last_name and first_name values match the customer_id, last_name, and first_name value of customer table.
Leave a Reply