With SQL Anywhere, there is no fixed limit on the number of tables you can join.
When joining more than two tables, parentheses are optional. If you do not use parentheses, SQL Anywhere evaluates the statement
from left to right. Therefore,
A JOIN B JOIN C is equivalent to
( A JOIN B ) JOIN C. Also, the following two SELECT statements are equivalent:
SELECT * FROM A JOIN B JOIN C JOIN D;
SELECT * FROM ( ( A JOIN B ) JOIN C ) JOIN D;
Whenever more than two tables are joined, the join involves table expressions. In the example
A JOIN B JOIN C, the table expression
A JOIN B is joined to C. This means, conceptually, that A and B are joined, and then the result is joined to C.
The order of joins is important if the table expression contains outer joins. For example,
A JOIN B LEFT OUTER JOIN C is interpreted as
(A JOIN B) LEFT OUTER JOIN C. This means that the table expression
A JOIN B is joined to C. The table expression
A JOIN B is preserved and table C is null-supplying.
Discuss this page in DocCommentXchange.
|Copyright © 2012, iAnywhere Solutions, Inc. - SQL Anywhere 12.0.1|