1. 21 Nov, 2013 1 commit
    • Igor Babaev's avatar
      Another attempt to fix bug mdev-5103. · c0f31dc9
      Igor Babaev authored
      The earlier pushed fix for the bug was incomplete. It did not remove
      the main cause of the problem: the function remove_eq_conds()
      removed always true multiple equalities from any conjunct, but did not
      adjust the list of them stored in Item_cond_and::cond_equal.current_level.
      
      Simplified the test case for the bug and moved it to another test file.
      
      The fix triggered changes in EXPLAIN EXTENDED for some queries. 
      c0f31dc9
  2. 14 Nov, 2013 4 commits
  3. 13 Nov, 2013 7 commits
  4. 12 Nov, 2013 1 commit
    • Sergei Golubchik's avatar
      MDEV-5113 Wrong result (extra row) and valgrind warnings in... · 441192bf
      Sergei Golubchik authored
      MDEV-5113 Wrong result (extra row) and valgrind warnings in Item_maxmin_subselect::any_value on 2nd execution of PS with SELECT subquery
      
      When setting Item_func_not_all::test_sum_item or Item_func_not_all::test_sub_item,
      reset the other one to NULL - they can never be set both. When a PS is reexecuted,
      different executions might be optimized differently and a wrong test_su*_item
      might stay set from the previous execution.
      441192bf
  5. 11 Nov, 2013 2 commits
    • unknown's avatar
      MDEV-5153: Server crashes in Item_ref::fix_fields on 2nd execution of PS with... · c98a054f
      unknown authored
      MDEV-5153: Server crashes in Item_ref::fix_fields on 2nd execution of PS with LEFT JOIN and MERGE view or SELECT SQ
      
      1. Transformation of row IN subquery made the same as single value.
      2. replace_where_subcondition() made working on several layers of OR/AND because it called on expression before fix_fields().
      c98a054f
    • unknown's avatar
      MDEV-5103: server crashed on singular Item_equal · c85db2c4
      unknown authored
      Singular Item_equal support added.
      
      The problem was that during constant table substitution Item_equal become containing only one constant which was not supported internally.
      c85db2c4
  6. 08 Nov, 2013 4 commits
  7. 29 Oct, 2013 2 commits
    • unknown's avatar
      MariaDB made be compiled by gcc 4.8.1 · 5ce11d8b
      unknown authored
        
        There was 2 problems:
        1) coping/moving of the same type (usually casting) as sizeof() (solved in different ways depends on the cause);
        2) using 'const' in SSL_CTX::getVerifyCallback() which return object (not reference) and so copy of the object will be created and 'const' has no sens.
      5ce11d8b
    • timour@askmonty.org's avatar
      MDEV-5104 crash in Item_field::used_tables with broken order by · 883af99e
      timour@askmonty.org authored
      Analysis:
      st_select_lex_unit::prepare() computes can_skip_order_by as TRUE.
      As a result join->prepare() gets called with order == NULL, and
      doesn't do name resolution for the inner ORDER clause. Due to this
      the prepare phase doesn't detect that the query references non-exiting
      function and field.
        
      Later join->optimize() calls update_used_tables() for a non-resolved
      Item_field, which understandably has no Field object. This call results
      in a crash.
      
      Solution:
      Resolve unnecessary ORDER BY clauses to detect if they reference non-exising
      objects. Then remove such clauses from the JOIN object.
      883af99e
  8. 21 Oct, 2013 4 commits
  9. 16 Oct, 2013 4 commits
  10. 11 Oct, 2013 1 commit
  11. 14 Oct, 2013 1 commit
  12. 12 Oct, 2013 1 commit
    • Igor Babaev's avatar
      Fixed bug mdev-5132. · 78b580b7
      Igor Babaev authored
      Objects of the classes Item_func_isnull and Item_func_isnotnull
      must have the flag sargable set to TRUE.
      Set the value of the flag sargable only in constructors of the 
      classes inherited from Item_int_func.
      78b580b7
  13. 11 Oct, 2013 1 commit
  14. 10 Oct, 2013 1 commit
    • Igor Babaev's avatar
      Fixed bug mdev-5105. · 7c87385e
      Igor Babaev authored
      The bug caused a memory overwrite in the function update_ref_and_keys()
      It happened due to a wrong value of SELECT_LEX::cond_count. This value
      historically was calculated by the fix_fields method. Now the logic of
      calling this method became too complicated and, as a result, this value
      is calculated not always correctly.
      The patch changes the way how and when  the values of SELECT_LEX::cond_count
      and of SELECT_LEX::between_count are calculated. The new code does it just at
      the beginning of update_ref_and_keys().
       
      7c87385e
  15. 04 Oct, 2013 1 commit
    • Igor Babaev's avatar
      Fixed bug mdev-5078. · ec226e55
      Igor Babaev authored
      For aggregated fields from views/derived tables the possible adjustment
      of thd->lex->in_sum_func->max_arg_level in the function Item_field::fix_fields
      must be done before we leave the function.
      ec226e55
  16. 03 Oct, 2013 1 commit
    • Igor Babaev's avatar
      Fixed bug mdev-5028. · 00816a96
      Igor Babaev authored
      Apparently in a general case a short-cut for the distinct optimization
      is invalid if join buffers are used to join tables after the tables whose
      values are to selected.
      00816a96
  17. 25 Sep, 2013 1 commit
  18. 16 Sep, 2013 3 commits