EXISTS Subquery condition
An EXISTS subquery condition evaluates to TRUE
if
the subquery returns a row. With an EXISTS subquery, one or more columns
can be returned. The subquery always contains a reference to a column
of the table in the main query. If you use an aggregate function in
an EXISTS subquery that includes no HAVING clause, at least one row
is always returned.
Element | Description | Restrictions | Syntax |
---|---|---|---|
subquery | Embedded query | Cannot contain the FIRST nor the ORDER BY clause | SELECT statement |
SELECT stock_num, manu_code FROM stock WHERE NOT EXISTS (SELECT stock_num, manu_code FROM items WHERE stock.stock_num = items.stock_num AND stock.manu_code = items.manu_code);
The preceding example works equally well if you use SELECT * in the subquery in place of the column names, because the existence of the entire row is tested; specific column values are not tested.