vonconrad
vonconrad

Reputation: 25377

MySQL join on record that might not exist

I'm trying to execute a query that looks similar to this:

SELECT <columns> FROM table1 
INNER JOIN table2 ON table1.id = table2.table1_id
INNER JOIN table3 ON table1.id = table3.table1_id
WHERE table3.column1 != 'foo' AND <other_conditions>
LIMIT 1;

The thing is--I want the query to return a result regardless of whether the record in table3 exists or not. That is--if the record in table3 is present, I want to check whether that record has a certain column value. If the record in table3 doesn't exist, I want the query to assume that the condition is TRUE.

Any pointers?

Upvotes: 4

Views: 3477

Answers (3)

Guffa
Guffa

Reputation: 700412

You use a left join on the table. If no corresponding record exists, the value from the table will be null, so you can use coalesce to get a value that you can compare to the string:

SELECT <columns> FROM table1 
INNER JOIN table2 ON table1.id = table2.table1_id
LEFT JOIN table3 ON table1.id = table3.table1_id
WHERE COALESCE(table3.column1, '') != 'foo' AND <other_conditions>
LIMIT 1

Upvotes: 7

Ruben
Ruben

Reputation: 9120

You need to use an outer join to include table3 instead of an inner join.

Upvotes: 0

Tomalak
Tomalak

Reputation: 338248

You've come to a point where you noticed that there is a difference between WHERE conditions and JOIN conditions.

SELECT 
  <columns> 
FROM
  table1 
  INNER JOIN table2 ON table2.table1_id = table1.id
  LEFT  JOIN table3 ON table3.table1_id = table1.id AND table3.column1 <> 'foo' 
WHERE
  <other_conditions>
LIMIT 1;

Upvotes: 3

Related Questions