Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

What is the default MySQL JOIN behaviour, INNER or OUTER?

Tags:

join

select

mysql

So I've been looking through the internet the last hour, reading and looking for the definitive answer to this simple question.

What is the default JOIN in MySQL?

SELECT * FROM t1 JOIN t2 

Is that the same as

SELECT * FROM t1, t2  OR  SELECT * FROM t1 INNER JOIN t2 

Also a related question, when you use "WHERE" clauses, is it the same as JOIN or INNER JOIN ?

Right now I'm thinking a stand-alone JOIN is identical to using commas and WHERE clauses.

like image 309
Quang Van Avatar asked Dec 11 '10 20:12

Quang Van


People also ask

Is default join inner or outer?

INNER is the default; LEFT, RIGHT, and FULL imply an outer join. The join condition is specified in the ON or USING clause, or implicitly by the word NATURAL. The join condition determines which rows from the two source tables are considered to "match", as explained in detail below.

Is default join Inner join?

The simplest and most common form of a join is the SQL inner join the default of the SQL join types used in most database management systems. It's the default SQL join you get when you use the join keyword by itself. The result of the SQL inner join includes rows from both the tables where the join conditions are met.

What is the default behavior of join in SQL?

JOIN defaults to INNER JOIN behaviour.

Is MySQL join inner join?

In MySQL, JOIN , CROSS JOIN , and INNER JOIN are syntactic equivalents (they can replace each other). In standard SQL, they are not equivalent. INNER JOIN is used with an ON clause, CROSS JOIN is used otherwise.


2 Answers

In MySQL writing JOIN unqualified implies INNER JOIN. In other words the INNER in INNER JOIN is optional. INNER and CROSS are synonyms in MySQL. For clarity I write JOIN or INNER JOIN if I have a join condition and CROSS JOIN if I don't have a condition.

The allowed syntax for joins is described in the documentation.


Right now I'm thinking a stand-alone JOIN is nothing more than (identical to) using commas and WHERE clauses.


The effect is the same, but the history behind them is different. The comma syntax is from the ANSI-89 standard. However there are a number of problems with this syntax so in the ANSI-92 standard the JOIN keyword was introduced.

I would strongly recommend that you always use JOIN syntax rather than the comma.

  • T1 JOIN T2 ON ... is more readable than T1, T2 WHERE ....
  • It is more maintainable because the table relationships and filters are clearly defined rather than mixed together.
  • The JOIN syntax is easier to convert to OUTER JOIN than the comma syntax.
  • Mixing the comma and JOIN syntax in the same statement can give curious errors due to the precedence rules.
  • It is less likely to accidentally create a cartesian product when using the JOIN syntax due to a forgotten join clause, because the join clauses are written next to the joins and it is easy to see if one is missing.
like image 104
Mark Byers Avatar answered Oct 13 '22 20:10

Mark Byers


These are all equivalent, and also equal to, CROSS JOIN.

There are some differences between using comma and [INNER | CROSS] JOIN syntax, which might be important when joining more tables. Pretty much all you need to know is described here in the MySQL JOIN documentation.

like image 40
Mchl Avatar answered Oct 13 '22 20:10

Mchl