Bug #94571 | The document of semi-joins is inconsistent with the server | ||
---|---|---|---|
Submitted: | 6 Mar 2019 3:16 | Modified: | 8 Mar 2019 9:29 |
Reporter: | Samuel Liang | Email Updates: | |
Status: | Not a Bug | Impact on me: | |
Category: | MySQL Server: Documentation | Severity: | S3 (Non-critical) |
Version: | OS: | Any | |
Assigned to: | CPU Architecture: | Any |
[6 Mar 2019 3:16]
Samuel Liang
[6 Mar 2019 14:52]
MySQL Verification Team
Hi, First of all, I do not see that the nested query is converted into semi-join, since the nested query is materialised. Second, transformation can not occur since the IN clause is not met by a single row, which is a condition for the transformation. Last, as our Manual states , you should run EXTENDED explain and then take a look at the warnings.
[7 Mar 2019 3:41]
Samuel Liang
Hi Sinisa I have run EXTENDED explain as above indeed and the warnings said "`ldy`.`t2` semi join (`ldy`.`t3`) straight_join `ldy`.`t1`". Doesn't that mean semijoin? Thanks
[7 Mar 2019 14:09]
MySQL Verification Team
Hi Samuel, Thank you for your feedback. That clears out the things. As the warning clearly puts out, straight join is between tables t1 and t2, while the semi-join is between tables t2 and t3. There is no straight_join clause on that join. Hence, our documentation is correct. Not a bug.
[8 Mar 2019 9:29]
Samuel Liang
Hi Sinisa Maybe I don't fully understand the documentation. So could you give me an example that could explain "The statement must not use the STRAIGHT_JOIN join type in the outer query."? Thanks
[8 Mar 2019 13:49]
MySQL Verification Team
This is actually very simple. Our documentation clearly points how to use straight_join so that all tables are affected.