Commit a24950a
Guilhem Bichot
Fix for Bug#19297190 NOT IN DOESN'T RETURN EXPECTED RESULT
We have a query with WHERE ... NOT IN (SELECT ...).
The inner field is 1503 bytes (500 chars * 3, because it has utf8 charset).
subquery_allows_materialization() considers subq-mat:
per the fix for Bug 17566396: MATERIALIZATION IS NOT CHOSEN FOR LONG
UTF8 VARCHAR FIELD, this field is small enough to _not_ be changed to a BLOB
when stored into the tmp table (Item::is_blob_field() sees that 500 <
CONVERT_IF_BIGGER_TO_BLOB), so subq-mat is chosen. Before that fix,
the left operand of the inequality comparison would be the length in
_bytes_ and subq-mat would not be chosen.
In hash_sj_engine::setup():
create_tmp_table() uses MEMORY table with a regular unique index,
without "unique constraint"; right after creation, setup() verifies
that the table has no "unique constraint", otherwise subq-mat would
fail - see comment in setup() and see how
indexsubquery_engine::setup() does a regular index lookup of a key
made with copy_ref_key(): to look up into "unique constraint" it would
need to compute a checksum in copy_ref_key().
So far so good.
At some point during materialization, MEMORY tmp table becomes full, we go
into create_myisam_from_heap() then create_myisam_tmp_table():
if (keyinfo->key_length >= table->file->max_key_length() ||
keyinfo->user_defined_key_parts > table->file->max_key_parts() ||
share->uniques)
{
/* Can't create a key; Make a unique constraint instead of a key */
share->keys= 0;
share->uniques= 1;
using_unique_constraint=1;
alas the first condition is 1503 > 1000 (engine is MyISAM) so we
create "unique constraint" on the MyISAM table. Subq-mat is not ready
for this, as we know, so we get a bad result: in fact, all look ups
then return "not found", so "NOT IN" always returns TRUE.
In 5.7, subq-mat has been made able to use "unique constraint" (see
Bug 18227171 which was part of wl 6711); however this same testcase
still crashes but for different reasons, a separate 5.7 patch will be
made.
For fixing 5.6:
- we cannot simply undo the fix for Bug 17566396 as there was an
associated customer
- on the other hand we cannot modify the logic in
create_myisam_tmp_table() to _not_ create a "unique constraint" in
this case (it's 5.6, we must be conservative)
- proposal: take a middle path: make subquery_allows_materialization()
test the length (by extending is_blob_field()): if length is >=1000
bytes, then don't use subq-mat (because there is risk that MyISAM
table is used and creates "unique constraint"). 1000 bytes is 333 utf8
characters. So we would have, for the limit of # of chars:
- before the fix for Bug 17566396: 512/3 = 170 chars,
- after it: 512 chars
- after the proposed fix: 332 chars.
The testcase in Bug 17566396 used 250 chars so still uses
subq-mat, which is good.1 parent c3e2977 commit a24950a
File tree
5 files changed
+225
-3
lines changed- mysql-test
- include
- r
- sql
5 files changed
+225
-3
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1417 | 1417 | | |
1418 | 1418 | | |
1419 | 1419 | | |
| 1420 | + | |
| 1421 | + | |
| 1422 | + | |
| 1423 | + | |
| 1424 | + | |
| 1425 | + | |
| 1426 | + | |
| 1427 | + | |
| 1428 | + | |
| 1429 | + | |
| 1430 | + | |
| 1431 | + | |
| 1432 | + | |
| 1433 | + | |
| 1434 | + | |
| 1435 | + | |
| 1436 | + | |
| 1437 | + | |
| 1438 | + | |
| 1439 | + | |
| 1440 | + | |
| 1441 | + | |
| 1442 | + | |
| 1443 | + | |
| 1444 | + | |
| 1445 | + | |
| 1446 | + | |
| 1447 | + | |
| 1448 | + | |
| 1449 | + | |
| 1450 | + | |
| 1451 | + | |
| 1452 | + | |
| 1453 | + | |
| 1454 | + | |
| 1455 | + | |
| 1456 | + | |
| 1457 | + | |
| 1458 | + | |
| 1459 | + | |
| 1460 | + | |
| 1461 | + | |
| 1462 | + | |
| 1463 | + | |
| 1464 | + | |
| 1465 | + | |
| 1466 | + | |
1420 | 1467 | | |
1421 | 1468 | | |
1422 | 1469 | | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1863 | 1863 | | |
1864 | 1864 | | |
1865 | 1865 | | |
| 1866 | + | |
| 1867 | + | |
| 1868 | + | |
| 1869 | + | |
| 1870 | + | |
| 1871 | + | |
| 1872 | + | |
| 1873 | + | |
| 1874 | + | |
| 1875 | + | |
| 1876 | + | |
| 1877 | + | |
| 1878 | + | |
| 1879 | + | |
| 1880 | + | |
| 1881 | + | |
| 1882 | + | |
| 1883 | + | |
| 1884 | + | |
| 1885 | + | |
| 1886 | + | |
| 1887 | + | |
| 1888 | + | |
| 1889 | + | |
| 1890 | + | |
| 1891 | + | |
| 1892 | + | |
| 1893 | + | |
| 1894 | + | |
| 1895 | + | |
| 1896 | + | |
| 1897 | + | |
| 1898 | + | |
| 1899 | + | |
| 1900 | + | |
| 1901 | + | |
| 1902 | + | |
| 1903 | + | |
| 1904 | + | |
| 1905 | + | |
| 1906 | + | |
| 1907 | + | |
| 1908 | + | |
| 1909 | + | |
| 1910 | + | |
| 1911 | + | |
| 1912 | + | |
| 1913 | + | |
| 1914 | + | |
| 1915 | + | |
| 1916 | + | |
| 1917 | + | |
| 1918 | + | |
1866 | 1919 | | |
1867 | 1920 | | |
1868 | 1921 | | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1876 | 1876 | | |
1877 | 1877 | | |
1878 | 1878 | | |
| 1879 | + | |
| 1880 | + | |
| 1881 | + | |
| 1882 | + | |
| 1883 | + | |
| 1884 | + | |
| 1885 | + | |
| 1886 | + | |
| 1887 | + | |
| 1888 | + | |
| 1889 | + | |
| 1890 | + | |
| 1891 | + | |
| 1892 | + | |
| 1893 | + | |
| 1894 | + | |
| 1895 | + | |
| 1896 | + | |
| 1897 | + | |
| 1898 | + | |
| 1899 | + | |
| 1900 | + | |
| 1901 | + | |
| 1902 | + | |
| 1903 | + | |
| 1904 | + | |
| 1905 | + | |
| 1906 | + | |
| 1907 | + | |
| 1908 | + | |
| 1909 | + | |
| 1910 | + | |
| 1911 | + | |
| 1912 | + | |
| 1913 | + | |
| 1914 | + | |
| 1915 | + | |
| 1916 | + | |
| 1917 | + | |
| 1918 | + | |
| 1919 | + | |
| 1920 | + | |
| 1921 | + | |
| 1922 | + | |
| 1923 | + | |
| 1924 | + | |
| 1925 | + | |
| 1926 | + | |
| 1927 | + | |
| 1928 | + | |
| 1929 | + | |
| 1930 | + | |
| 1931 | + | |
1879 | 1932 | | |
1880 | 1933 | | |
1881 | 1934 | | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1862 | 1862 | | |
1863 | 1863 | | |
1864 | 1864 | | |
| 1865 | + | |
| 1866 | + | |
| 1867 | + | |
| 1868 | + | |
| 1869 | + | |
| 1870 | + | |
| 1871 | + | |
| 1872 | + | |
| 1873 | + | |
| 1874 | + | |
| 1875 | + | |
| 1876 | + | |
| 1877 | + | |
| 1878 | + | |
| 1879 | + | |
| 1880 | + | |
| 1881 | + | |
| 1882 | + | |
| 1883 | + | |
| 1884 | + | |
| 1885 | + | |
| 1886 | + | |
| 1887 | + | |
| 1888 | + | |
| 1889 | + | |
| 1890 | + | |
| 1891 | + | |
| 1892 | + | |
| 1893 | + | |
| 1894 | + | |
| 1895 | + | |
| 1896 | + | |
| 1897 | + | |
| 1898 | + | |
| 1899 | + | |
| 1900 | + | |
| 1901 | + | |
| 1902 | + | |
| 1903 | + | |
| 1904 | + | |
| 1905 | + | |
| 1906 | + | |
| 1907 | + | |
| 1908 | + | |
| 1909 | + | |
| 1910 | + | |
| 1911 | + | |
| 1912 | + | |
| 1913 | + | |
| 1914 | + | |
| 1915 | + | |
| 1916 | + | |
| 1917 | + | |
1865 | 1918 | | |
1866 | 1919 | | |
1867 | 1920 | | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1516 | 1516 | | |
1517 | 1517 | | |
1518 | 1518 | | |
1519 | | - | |
1520 | | - | |
1521 | | - | |
| 1519 | + | |
| 1520 | + | |
| 1521 | + | |
| 1522 | + | |
| 1523 | + | |
| 1524 | + | |
| 1525 | + | |
| 1526 | + | |
| 1527 | + | |
| 1528 | + | |
| 1529 | + | |
| 1530 | + | |
| 1531 | + | |
| 1532 | + | |
| 1533 | + | |
| 1534 | + | |
| 1535 | + | |
| 1536 | + | |
| 1537 | + | |
1522 | 1538 | | |
1523 | 1539 | | |
1524 | 1540 | | |
| |||
0 commit comments