2006-10-10 17:33:26 +00:00
|
|
|
Syntax:
|
|
|
|
<div class='sql'>
|
|
|
|
<pre>
|
2006-10-10 20:52:10 +00:00
|
|
|
<i>operand</i> IN (<i>subquery</i>|<i>value list</i>)
|
2006-10-10 17:33:26 +00:00
|
|
|
</pre>
|
|
|
|
</div>
|
|
|
|
An IN conditional expression returns true if the <i>operand</i> is found from result of the <i>subquery</i>
|
2006-10-10 20:52:10 +00:00
|
|
|
or if its in the specificied comma separated <i>value list</i>, hence the IN expression is always false if the result of the subquery
|
2006-10-10 17:33:26 +00:00
|
|
|
is empty.
|
|
|
|
|
2006-10-10 20:52:10 +00:00
|
|
|
When <i>value list</i> is being used there must be at least one element in that list.
|
|
|
|
|
2006-10-10 17:33:26 +00:00
|
|
|
<div class='sql'>
|
|
|
|
<pre>
|
|
|
|
FROM C1 WHERE C1.col1 IN (FROM C2(col1));
|
|
|
|
|
|
|
|
FROM User WHERE User.id IN (1,3,4,5)
|
|
|
|
</pre>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
The keyword IN is an alias for = ANY. Thus, these two statements are equal:
|
|
|
|
<div class='sql'>
|
|
|
|
<pre>
|
|
|
|
FROM C1 WHERE C1.col1 = ANY (FROM C2(col1));
|
|
|
|
FROM C1 WHERE C1.col1 IN (FROM C2(col1));
|
|
|
|
</pre>
|
|
|
|
</div>
|
|
|
|
|