Bug #2996 | update on left join can change non matching record in second table. | ||
---|---|---|---|
Submitted: | 27 Feb 2004 11:57 | Modified: | 11 Mar 2004 12:23 |
Reporter: | Joseph Martin | Email Updates: | |
Status: | Closed | Impact on me: | |
Category: | MySQL Server | Severity: | S2 (Serious) |
Version: | 4.0.18 | OS: | Linux (Linux 2.4.25 (Slackware 9.1+)) |
Assigned to: | CPU Architecture: | Any |
[27 Feb 2004 11:57]
Joseph Martin
[1 Mar 2004 9:06]
Dean Ellis
Verified against 4.0.19. Thank you for the test case.
[3 Mar 2004 8:20]
MySQL Verification Team
Thank you for your bug report. This issue has been committed to our source repository of that product and will be incorporated into the next release. If necessary, you can access the source repository and build the latest available version, including the bugfix, yourself. More information about accessing the source trees is available at http://www.mysql.com/doc/en/Installing_source_tree.html Additional info: Fix will come in 4.0.19
[11 Mar 2004 12:23]
MySQL Verification Team
Fixed in 4.0.19 with the following patch: ===== /mnt/work/mysql-4.0/sql/sql_select.cc 1.276 vs edited ===== *** /tmp/sql_select.cc-1.276-28277 Wed Mar 10 11:50:15 2004 --- edited//mnt/work/mysql-4.0/sql/sql_select.cc Thu Mar 11 16:39:27 2004 *************** *** 4897,4904 **** if (tab->on_expr && !table->null_row) { if ((table->null_row= test(tab->on_expr->val_int() == 0))) ! empty_record(table); ! } if (!table->null_row) table->maybe_null=0; DBUG_RETURN(0); --- 4897,4904 ---- if (tab->on_expr && !table->null_row) { if ((table->null_row= test(tab->on_expr->val_int() == 0))) ! mark_as_null_row(table); ! } if (!table->null_row) table->maybe_null=0; DBUG_RETURN(0); ChangeSet info: 1.1745: +3 -0 = 10639