Q
Problem solve Get help with specific problems with your technologies, process and projects.

# Outer join with a condition

Is there a way to emulate the functionality of this without a subquery:

```SELECT Id, Name
FROM Table1
WHERE Table1.Id NOT IN
( SELECT Id
FROM Table2
WHERE Flag=2 )```

I know without the where clause on Table2, this can be done with an outer/left join... However, the where clause on the Flag is really confusing me.

Let's create some test data to try our queries on:

```Table1             Table2
Id  Name           Id  Flag
91  Curly          91   2
92  Larry          92   1
93  Moe            93  null
94  Shemp
95  Joe
96  Curly Joe```

Notice that there is:

• a matching row where Flag is 2 (Curly)
• a matching row where Flag is not 2 (Larry)
• a matching row where Flag is null (Moe)
• several non-matching rows (Shemp, Joe, and Curly Joe)

Your original query has this subquery:

```select Id
from Table2
where Flag=2```

This returns only 91 (Curly). Your main query therefore returns everybody except Curly. This what we will try to do without using a subquery.

Let's take a look at the approach you suggested, a LEFT OUTER join, but let's omit the Flag test initially:

```select Table1.Id as Id1, Name
, Table2.Id as Id2, Flag
from Table1
left outer
join Table2
on Table1.Id = Table2.Id

Id1 Name       Id2 Flag
91 Curly       91   2
92 Larry       92   1
93 Moe         93  null
94 Shemp      null null
95 Joe        null null
96 Curly Joe  null null```

Notice that columns from both Table1 and Table2 are in the SELECT list, so that we can see actual result set values as returned by the LEFT OUTER join. As you may know, in unmatched rows, columns from the right table are set to null. We can tell which rows had a match by looking at Id2, but not by looking at Flag, because Moe has a null stored in Table2, whereas Shemp, Joe, and Curly Joe don't.

Now let's add the Flag test to the ON condition:

```select Table1.Id as Id1, Name
, Table2.Id as Id2, Flag
from Table1
left outer
join Table2
on Table1.Id = Table2.Id
and             Flag <> 2

Id1 Name       Id2 Flag
91 Curly      null null
92 Larry       92   1
93 Moe        null null
94 Shemp      null null
95 Joe        null null
96 Curly Joe  null null```

Wait a second! How can this be? Why is Curly returned?

The answer is that in a LEFT OUTER join, each row of the left table must be returned, regardless of any ON conditions that may or may not bring in matching rows from the other table.

If this is confusing, let's walk through an example. Id1=91 (Curly) has a matching Id2, but its Flag is 2, so the ON conditions are not satisfied. But it's a LEFT OUTER Join, so Curly is returned anyway, with columns from Table2 set to null. Id2 is null whenever the ON conditions were not satisfied.

The solution is to move the Flag test to the WHERE clause, and allow for non-matching rows as well:

```select Table1.Id as Id1, Name
, Table2.Id as Id2, Flag
from Table1
left outer
join Table2
on Table1.Id = Table2.Id
where Flag is null
or Flag <> 2

Id1 Name       Id2 Flag
92 Larry       92   1
93 Moe         93  null
94 Shemp      null null
95 Joe        null null
96 Curly Joe  null null```

Now we have the results we want -- everybody except Curly -- without needing a subquery.

(This is for MySQL, right?)

#### Start the conversation

Send me notifications when other members comment.

## SearchDataManagement

• ### EnterpriseDB looks to grow market for PostgreSQL

Enterprises are increasingly using the open source PostgreSQL database. Read in this Q&A where the growth is coming from and how ...

• ### 3 of the top use cases for graph databases

Graph databases establish many unique relationships between data points. These unusual relationships are beneficial in many use ...

• ### Dell EMC Streaming Data Platform integrates open source technology

Dell combines several open source streaming data technologies, including Apache Kafka, Apache Flink and Pravega, to create a new ...

• ### What Salesforce means for Tableau in the cloud

After the Salesforce acquisition, users have wondered about the future of Tableau in the cloud. Experts weigh in on how the ...

• ### MicroStrategy analytics suite fosters insurance co-op's growth

Using MicroStrategy's BI platform, a Canada-based insurance co-operative has been able to spread analytics to end users ...

• ### Yellowbrick Data, MicroStrategy partnership aims to enhance analytics

The new partnership will enable flexible scalability, support for mixed workloads and multi-cloud support. The goal is to provide...

## SearchSAP

• ### 5 tips for a successful S/4HANA Cloud implementation

Moving to S/4HANA public cloud can help you save on IT maintenance and simplify real-time analysis. Here's a look at what you can...

• ### Take care of data before SAP S/4HANA migration

In this Q&A, Rajesh Rengarethinam of ERP security vendor Appsian discusses why reviewing data security and business processes are...

Business Suite 7 will receive mainstream maintenance until 2027, a decision industry observers say reflects the difficulty of an ...

## SearchSQLServer

• ### SQL Server database design best practices and tips for DBAs

Good database design is a must to meet processing needs in SQL Server systems. In a webinar, consultant Koen Verbeeck offered ...

• ### SQL Server in Azure database choices and what they offer users

SQL Server databases can be moved to the Azure cloud in several different ways. Here's what you'll get from each of the options ...

• ### Using a LEFT OUTER JOIN vs. RIGHT OUTER JOIN in SQL

In this book excerpt, you'll learn LEFT OUTER JOIN vs. RIGHT OUTER JOIN techniques and find various examples for creating SQL ...

## TheServerSide.com

• ### Why the 8 Java primitive data types are not objects

What's the difference between Java primitive types and objects? To start, don't classify primitive types as objects. Let's ...

• ### A brief history of Java: How it forever changed programming

The Java programming language is an important tool in an application developer's quiver. But Java has also undergone many changes...

• ### How to properly perform Java String comparisons

Don't let incorrect Java String object comparisons bog down your code. Follow this tutorial to understand the differences between...

## SearchDataCenter

• ### Learn the main Linux OS components

Linux is one operating choice to run on your infrastructure. Get started with these terms to discover how the OS works and how it...

• ### New Dell EMC PowerEdge servers are built for the rugged edge

New Dell Streaming Media Platform includes two small form factor PowerEdge servers and a Modular Data Center. Dell aims the ...

• ### Initiative aims to improve data center incident reporting

The Data Center Incident Reporting Network hopes to pull back the smoke screen on software and hardware issues to improve ...

## SearchContentManagement

• ### Test yourself on the differences between SharePoint and OneDrive

Businesses use Microsoft SharePoint and OneDrive capabilities for a number of reasons. Test your knowledge on the differences ...

• ### Akeneo rolls out newest version of PIM software

Akeneo PIM version 4.0 features digital asset manager, API-integrated connection modules and AI attribute mapping to better ...

• ### Get to know 4 workflow automation tools

Workflow automation can benefit businesses by making manual processes digital, giving employees more time to work on other tasks....

## SearchHRSoftware

• ### How real-time analytics can benefit HR

For analytics to be truly useful, it must be embedded into user workflows. Learn how HR tools are incorporating such approaches ...

• ### Human vs. AI in recruiting: Why both matter

Recruiters may consider using both the human element and the data brought in by intelligent tools if it can help them make better...

• ### Kronos-Ultimate Software merger creates \$3B firm with product overlap

Kronos Inc. and Ultimate Software are being merged by their private equity owner into a new, yet unnamed, entity. How this will ...

Close