Select from one table based on condition in another

SQL expert Rudy Limeback explains how to select from one table based on condition in another using an inner join in Oracle.

I need to select all data from Table_A for employees in Unit ABC123, but the Unit code is in Table_B. The common key is Emplid. I need to create an Oracle Export script to basically replace the following code:

SELECT A.* FROM TABLE_A A
WHERE exists
(SELECT B.EMPLID from TABLE_B B
  where A.EMPLID = B.EMPLID 
    and B.UNIT   = 'ABC123')

Is an Export script possible?

Sounds like what you're looking for is an inner join.

SELECT A.* 
  FROM TABLE_A A
INNER
  JOIN TABLE_B B
    ON B.EMPLID = A.EMPLID 
   AND B.UNIT   = 'ABC123'

The only problem you will have is if the relationship between TABLE_A and TABLE_B is one-to-many. Since you are using the dreaded, evil "select star"—presumably you did this only for convenience in posing the question, and would not do it in real life—you will find it difficult to use GROUP BY, because the GROUP BY would have to include every column being selected.

But there's an easier way. Push the GROUP BY down into a derived table subquery, so that TABLE_A joins to only one row derived from TABLE_B:

SELECT A.* 
  FROM TABLE_A A
INNER
  JOIN ( SELECT EMPLID
           FROM TABLE_B 
          WHERE UNIT = 'ABC123'
         GROUP
             BY EMPLID ) B
    ON B.EMPLID = A.EMPLID

This eliminates the one-to-many problem in the outer query.

Dig Deeper on Oracle development languages

Data Management
Business Analytics
SearchSAP
TheServerSide.com
  • Why WebAssembly? Top 11 Wasm benefits

    Latency and lag time plague web applications that run JavaScript in the browser. Here are 11 reasons why WebAssembly has the ...

  • Why Java in 2023?

    Has there ever been a better time to be a Java programmer? From new Spring releases to active JUGs, the Java platform is ...

  • How developers can avoid remote work scams

    Software developers can find good remote programming jobs, but some job offers are too good to be true. Follow these tips to spot...

Data Center
Content Management
HRSoftware
Close