mirror of
https://github.com/MariaDB/server.git
synced 2025-07-29 05:21:33 +03:00
MDEV-5037: Server crash on a JOIN on a derived table with join_cache_level > 2
- The crash was caused because the optimizer called handler->multi_range_read_info() on a derived temporary table. That table has been created, but not opened yet. Because of that, handler::table was NULL, which caused crash. Fixed by changing DS-MRR methods to use handler::table_share instead. handler::table_share is set in handler ctor, so this should be safe.
This commit is contained in:
@ -192,7 +192,7 @@ public:
|
||||
(PREV_BITS(key_part_map, max_loose_keypart+1) & // (3)
|
||||
(found_part | loose_scan_keyparts)) == // (3)
|
||||
PREV_BITS(key_part_map, max_loose_keypart+1) && // (3)
|
||||
!key_uses_partial_cols(s->table, key))
|
||||
!key_uses_partial_cols(s->table->s, key))
|
||||
{
|
||||
/* Ok, can use the strategy */
|
||||
part1_conds_met= TRUE;
|
||||
|
Reference in New Issue
Block a user