1. 23 Apr, 2018 1 commit
    • Alexander Barkov's avatar
      MDEV-15957 Unexpected "Data too long" when doing CREATE..SELECT with stored func · 6426b52e
      Alexander Barkov authored
      Problems:
      
      1. Unlike Item_field::fix_fields(),
        Item_sum_sp::fix_length_and_dec() and Item_func_sp::fix_length_and_dec()
        did not run the code which resided in adjust_max_effective_column_length(),
        therefore they did not extend max_length for the integer return data types
        from the user-specified length to the maximum length according to
        the data type capacity.
      
      2. The code in adjust_max_effective_column_length() was not correct
         for TEXT data, because Field_blob::max_display_length()
         multiplies to mbmaxlen. So TEXT variants were unintentionally
         promoted to the next longer data type for multi-byte character
         sets: TINYTEXT->TEXT, TEXT->MEDIUMTEXT, MEDIUMTEXT->LONGTEXT.
      
      3. Item_sum_sp::create_table_field_from_handler()
         Item_func_sp::create_table_field_from_handler()
         erroneously called tmp_table_field_from_field_type(),
         which converted VARCHAR(>512) to TEXT variants.
         So "CREATE..SELECT spfunc()" erroneously converted
         VARCHAR to TEXT. This was wrong, because stored
         functions have explicitly declared data types,
         which should be preserved.
      
      Solution:
      
      - Removing Type_std_attributes(const Field *)
        and using instead Type_std_attributes::set() in combination
        with field->type_str_attributes() all around the code, e.g.:
           Type_std_attributes::set(field->type_std_attributes())
      
        These two ways of copying attributes from a Field
        to an Item duplicated each other, and were slightly
        different in how to mix max_length and mbmaxlen.
      
      - Removing adjust_max_effective_column_length() and
        fixing Field::type_std_attributes() to do all necessary
        type-specific calculations , so no further adjustments
        is needed.
        Field::type_std_attributes() is now called from all affected methods:
         Item_field::fix_fields()
         Item_sum_sp::fix_length_and_dec()
         Item_func_sp::fix_length_and_dec()
        This fixes the problem N1.
      
      - Making Field::type_std_attributes() virtual, to make
        sure that type-specific adjustments a properly done
        by individual Field_xxx classes. Implementing
        Field_blob::type_std_attributes() in the way that
        no TEXT promotion is done.
        This fixes the problem N2.
      
      - Fixing Item_sum_sp::create_table_field_from_handler()
        Item_func_sp::create_table_field_from_handler() to
        call create_table_field_from_handler() instead of
        tmp_table_field_from_field_type() to avoid
        VARCHAR->TEXT conversion on "CREATE..SELECT spfunc()".
      
      - Recording mysql-test/suite/compat/oracle/r/sp-param.result
        as "CREATE..SELECT spfunc()" now correctly
        preserve the data type as specified in the RETURNS clause.
      
      - Adding new tests
      6426b52e
  2. 22 Apr, 2018 3 commits
  3. 21 Apr, 2018 2 commits
  4. 20 Apr, 2018 7 commits
    • Alexander Barkov's avatar
      Adding more tests for IN/EXIST subqueries for better coverage · c058117c
      Alexander Barkov authored
      Adding tests with IN/EXISTS subqueries in various rarely unexpected places:
      
      - non-SELECT statements
      - SP control
      - cursors
      
      etc.
      c058117c
    • Sergey Vojtovich's avatar
      Fixed compiler warning · 791fb9ea
      Sergey Vojtovich authored
      791fb9ea
    • Alexander Barkov's avatar
      MDEV-15926 MEDIUMINT returns wrong I_S attributes · 9aaf62d0
      Alexander Barkov authored
      Problem:
      
      The logic in store_column_type() with a switch on field type was
      hard to follow. The part for MEDIUMINT (MYSQL_TYPE_INT24) was not correct.
      It erroneously calculated the precision of MEDIUMINT UNSIGNED
      as 7 instead of 8.
      
      A similar hard-to-follow switch doing some type specific calculations
      resided in adjust_max_effective_column_length(). It was also wrong for
      MEDIUMINT (reported as a separate issue in MDEV-15946).
      
      Solution:
      
      1. Introducing a new class Information_schema_numeric_attributes
      2. Adding a new virtual method Field::information_schema_numeric_attributes()
      3. Splitting the logic in store_column_type() into virtual
         implementations of information_schema_numeric_attributes().
      4. In order to avoid adding duplicate code for the integer data types,
         adding a new virtual method Field_int::numeric_precision(),
         which returns the number of digits.
      
      Additional changes:
      
      1. Adding the "const" qualifier to Field::max_display_length()
      
      2. Moving the code from adjust_max_effective_column_length()
        directly to Field::max_display_length().
        There was no any sense to have two implementations:
        - a set of wrong virtual implementations for Field_xxx::max_display_length()
        - additional code in adjust_max_effective_column_length() fixing
          bad results of Field_xxx::max_display_length()
        This change is safe:
        - The code using Field::max_display_length()
          in field.cc, sql_show.cc, sql_type.cc is not affected.
        - The code in rpl_utility.cc is also not affected.
          See a new DBUG_ASSSERT and new comments explaining why.
      
        In the new reduction, Field_xxx::max_display_length() returns
        correct results for all integer types (except MEDIUMINT, see below).
      
        Putting implementations of numeric_precision() and max_display_length()
        near each other in field.h made the logic much clearer and thus
        helped to reveal bad results for Field_medium::max_display_length(),
        which returns 9 instead of 8 for signed MEDIUMINT fields.
        This problem will be addressed separately (MDEV-15946).
      
      Note, this change is also useful for pluggable data types (see MDEV-4912),
      as now a user defined Field_xxx has a way to control what's returned
      in INFORMATION_SCHEMA.COLUMNS.NUMERIC_PRECISION and
      INFORMATION_SCHEMA.COLUMNS.NUMERIC_SCALE by implementing
      a desired behavior in Field_xxx::information_schema_numeric_attributes().
      9aaf62d0
    • Sergey Vojtovich's avatar
      MDEV-15763 - VARCHAR(1) COMPRESSED crashes the server · 38c799c9
      Sergey Vojtovich authored
      Storing 1 byte long string in VARCHAR() COMPRESSED column may trigger
      integer overflow when calculating available space for zlib output.
      38c799c9
    • Sergey Vojtovich's avatar
      MDEV-15762 - VARCHAR(0) COMPRESSED crashes the server · 3dec6c48
      Sergey Vojtovich authored
      Character set safe truncation is done when storing non-empty string in
      VARCHAR(0) COMPRESSED column, so that string becomes empty. The code
      didn't expect empty string after truncation.
      
      Fixed by moving empty string check after truncation.
      3dec6c48
    • Sachin Setiya's avatar
      Buildbot fixes · 43ab88f0
      Sachin Setiya authored
      1 Added typecast
      2 Included have_debug.inc
      43ab88f0
    • Igor Babaev's avatar
      MDEV-15902 Assertion `n < m_size' failed, sql_array.h:64: · 615ad709
      Igor Babaev authored
      Element_type& Bounds_checked_array<Element_type>::operator[]
      (size_t) [with Element_type = Item*; size_t = long unsigned int]
      
      In sql_yacc.yy the semantic actions for the MEDIAN window function
      lacked a call of st_select_lex::prepare_add_window_spec().
      This function saves the head of the thd->lex->order_list into
      lex->save_order_list in order this head to be restored in
      st_select_lex::add_window_spec after the specification of the
      window function has been parsed.
      Without a call of prepare_add_window_spec() when add_window_spec()
      was called the head of an empty list was copied into
      thd->lex->order_list (instead of assumed saved head this list).
      This made the list thd->lex->order_list invalid and potentially
      could cause many different problems.
      
      Corrected the result set in the test case for MDEV-15899 that
      used the MEDIAN window function and could not be correct
      without this fix.
      615ad709
  5. 19 Apr, 2018 5 commits
    • Sachin Setiya's avatar
      MDEV-15167 Server crashes in in bitmap_bits_set upon REPAIR PARTITION... · cd8b8169
      Sachin Setiya authored
      after rebuilding under test_pseudo_invisible
      
      If we are doing alter related to partitioning then simple alter stmt
      like adding column(or any alter stmt) can't be combined with partition
      alter, this will generate a syntax error.
      
      But IF we add
      SET debug_dbug="+d,test_pseudo_invisible";
      or test_completely_invisible
      this will add a column to table  with have an already partitioning related
      alter. This execution of wrong stmt will crash the server on later stages.
      (like on repair partition).
      
      So we will simply return 1 (and ER_INTERNAL_ERROR) if we any of these
      debug_dbug flags turned on.
      cd8b8169
    • Marko Mäkelä's avatar
      Merge 10.2 to 10.3 · d71a8855
      Marko Mäkelä authored
      Temporarily disable main.cte_recursive due to hang in
      an added test related to MDEV-15575.
      d71a8855
    • Sachin Setiya's avatar
      Mdev-10664 Add statuses about optimistic parallel replication stalls · 419385db
      Sachin Setiya authored
      In this commit we are adding three more status variable to SHOW SLAVE
      STATUS.  Slave_DDL_Events and Slave_Non_Transactional_Events.
      
      Slave_DDL_Groups:- This status variable counts the occurrence of DDL
      statements
      
      Slave_Non_Transactional_Groups:- This variable count the occurrence
      of non-transnational event group.
      
      Slave_Transactional_Groups:- This variable count the occurrence
      of transnational event group.
      
      Patch Credit:- Kristian Nielsen
      419385db
    • Sachin Setiya's avatar
      MDEV-12924 No --innodb-numa-interleave in mysqld binaries · 547b00d9
      Sachin Setiya authored
      It changes the cmake WITH_NUMA option to have 3 values
      Auto:- If libnuma present compile with numa (Default value)
      OFF:- Compile without libnuma
      On:- Compile with numa , throw error if libnuma not present
      
      Patch Contributer:- Vesa
      Patch Reviewer:- serg
      547b00d9
    • Sachin Setiya's avatar
      MDEV-15754 Server crashes in fill_record_n_invoke_before_triggers upon ... · dde0ba5a
      Sachin Setiya authored
      insert into table with TIMESTAMP INVISIBLE
      
      Problem:- The segfault occurs because value is null but since timestamp field
      is VISIBLE it expects a value , and it tries to call value->save_in_field(..
      Timestamp field should not be visible this is the problem.
      
      Solution:- While we clone field for record0_field we don't honor the field
      _visibility , this patch changes that.
      dde0ba5a
  6. 18 Apr, 2018 4 commits
  7. 17 Apr, 2018 4 commits
  8. 16 Apr, 2018 14 commits