Из документации Oracle
http://docs.oracle.com/cd/E11882_01/server.112/e26088/queries004.htm#SQLRF52341
«МИНУС Пример Следующий оператор объединяет результаты с оператором МИНУС, который возвращает только уникальные строки, возвращаемые первого запроса, но а не вторым: «
SELECT product_id FROM inventories
MINUS
SELECT product_id FROM order_items;
Ваши требования немного сложнее. Я полагаю, что сочетание cols_a, cols_b, cols_c, cols_d является уникальным для записи в таблице А. В этом случае, следующий код должен решить проблему:
create table A (
cols_date DATE,
cols_a NUMBER,
cols_b NUMBER,
cols_c NUMBER,
cols_d NUMBER
);
create table B (
cols_a NUMBER,
cols_b NUMBER,
cols_c NUMBER,
cols_d NUMBER
);
insert into A (cols_date, cols_a, cols_b, cols_c, cols_d) values (sysdate, 1, 1, 1, 1);
insert into A (cols_date, cols_a, cols_b, cols_c, cols_d) values (sysdate, 2, 2, 2, 2);
insert into B (cols_a, cols_b, cols_c, cols_d) values (2, 2, 2, 2);
insert into B (cols_a, cols_b, cols_c, cols_d) values (3, 3, 3, 3);
commit;
select a.cols_date, a.cols_a, a.cols_b, a.cols_c, a.cols_d from (
select cols_a, cols_b, cols_c, cols_d
from A
minus
select cols_a, cols_b, cols_c, cols_d
from b
) ma, a
where 1=1
and ma.cols_a = a.cols_a
and ma.cols_b = a.cols_b
and ma.cols_c = a.cols_c
and ma.cols_d = a.cols_d;
Результат
COLS_DATE COLS_A COLS_B COLS_C COLS_D
--------------------- ---------- ---------- ---------- ----------
01.07.2013 13:20:02 1 1 1 1
НЕ СУЩЕСТВУЕТ также решить эту проблему. Это утверждение имеет лучший план выполнения, а затем версию MINUS.
Благодаря Дэвиду Олдриджу за это решение.
select
cols_date,
cols_a, cols_b, cols_c, cols_d
from
a
where
not exists (
select 1
from b
where 1=1
and b.cols_a = a.cols_a
and b.cols_b = a.cols_b
and b.cols_c = a.cols_c
and b.cols_d = a.cols_d
);
Какая общая колонка в таблице A и B? – user75ponic