1. 08 Jul, 2008 3 commits
  2. 07 Jul, 2008 8 commits
    • Mattias Jonsson's avatar
    • Marc Alff's avatar
      Manual merge of bug#26030 in mysql-5.1-bugteam · e59c5656
      Marc Alff authored
      e59c5656
    • Mattias Jonsson's avatar
      merge · dd5966a8
      Mattias Jonsson authored
      dd5966a8
    • Mattias Jonsson's avatar
      Bug#35745: SELECT COUNT(*) is not correct for some partitioned tables. · 19a48cdf
      Mattias Jonsson authored
      problem was that ha_partition::records was not implemented, thus
      using the default handler::records, which is not correct if the engine
      does not support HA_STATS_RECORDS_IS_EXACT.
      Solution was to implement ha_partition::records as a wrapper around
      the underlying partitions records.
      
      The rows column in explain partitions will now include the total
      number of records in the partitioned table.
      
      (recommit after removing out-commented code)
      19a48cdf
    • Marc Alff's avatar
      Merge · ce79abc1
      Marc Alff authored
      ce79abc1
    • Marc Alff's avatar
      Bug#26030 (Parsing fails for stored routine w/multi-statement execution · 2b285467
      Marc Alff authored
      enabled)
      
      Before this fix, the lexer and parser would treat the ';' character as a
      different token (either ';' or END_OF_INPUT), based on convoluted logic,
      which failed in simple cases where a stored procedure is implemented as a
      single statement, and used in a multi query.
      
      With this fix:
      - the character ';' is always parsed as a ';' token in the lexer,
      - parsing multi queries is implemented in the parser, in the 'query:' rules,
      - the value of thd->client_capabilities, which is the capabilities
        negotiated between the client and the server during bootstrap,
        is immutable and not arbitrarily modified during parsing (which was the
        root cause of the bug)
      
      2b285467
    • Georgi Kodinov's avatar
      Bug#37627: addendum : · 574eefeb
      Georgi Kodinov authored
       - moved the test into a separate file to check for presence of the test variable
      
      mysql-test/r/subselect.result:
        Bug#37627: moved the test to a separate file
      mysql-test/r/subselect_debug.result:
        Bug#37627: moved the test to a separate file
      mysql-test/t/subselect.test:
        Bug#37627: moved the test to a separate file
      mysql-test/t/subselect_debug.test:
        Bug#37627: moved the test to a separate file
      574eefeb
    • Mats Kindahl's avatar
      Bug #37150 Risk for crash in User_var_log_event::exec_event() · dd6537c1
      Mats Kindahl authored
      On certain kinds of errors (e.g., out of stack), a call to Item_func_
      set_user_var::fix_fields() might fail.  Since the return value of this
      call was not checked inside User_var_log_event::exec_event(), continuing
      execution after this will cause a crash inside Item_func_set_user_var::
      update_hash().
      
      The bug is fixed by aborting execution of the event with an error if
      fix_fields() fails, since it is not possible to continue execution anyway.
      
      
      sql/log_event.cc:
        Aborting execution of event if fix_fields() fails since execution
        of update_hash() might cause a crash.
      dd6537c1
  3. 04 Jul, 2008 5 commits
  4. 03 Jul, 2008 3 commits
    • Konstantin Osipov's avatar
      A fix for · 5fc65e78
      Konstantin Osipov authored
      Bug#12093 "SP not found on second PS execution if another thread 
      drops other SP in between" and
      Bug#21294 "executing a prepared statement that executes a stored 
      function which was recreat"
      
      Stored functions are resolved at prepared statement prepare only.
      If someone flushes the stored functions cache between prepare and
      execute, execution fails.
      
      The fix is to detect the situation of the cache flush and automatically
      reprepare the prepared statement after it.
      
      mysql-test/r/ps_ddl.result:
        Update results (Bug#12093 and Bug#21294, the test cases are already
        in the source tree).
      mysql-test/r/ps_ddl1.result:
        Update results (Bug#12093 and Bug#21294, the test cases are already
        in the source tree).
      mysql-test/r/sp-error.result:
        Update results (Bug#12093 and Bug#21294, the test cases are already
        in the source tree).
      mysql-test/t/ps_ddl.test:
        Modify the test to not expect an error where there is no error
        any more (Bug#12093, Bug#21294).
      mysql-test/t/ps_ddl1.test:
        Modify the test to not expect an error where there is no error
        any more (Bug#12093, Bug#21294).
      mysql-test/t/sp-error.test:
        Modify the test to not expect an error where there is no error
        any more (Bug#12093, Bug#21294).
      sql/sp_cache.cc:
        Implement sp_cache_version() -- returns the current version of 
        a stored routines cache.
      sql/sp_cache.h:
        Declare sp_cache_version().
      sql/sql_prepare.cc:
        Keep track of stored functions cache version, and invalidate
        the statement if it changed between prepared statement
        prepare and execute (and the statement actually uses stored routines).
      5fc65e78
    • Sven Sandberg's avatar
      merge · 291ebbae
      Sven Sandberg authored
      291ebbae
    • Sven Sandberg's avatar
      BUG#37200: rpl_switch_stm_row_mixed fails sporadically in pushbuild · dccc55d5
      Sven Sandberg authored
      This bug has been fixed in two slightly different ways in
      6.0-rpl and {5.1,6.0}-bugteam. To avoid future merge
      problems, I'm now copying the 6.0-rpl fix to 5.1-bugteam.
      dccc55d5
  5. 02 Jul, 2008 3 commits
  6. 01 Jul, 2008 3 commits
    • Patrick Crews's avatar
      upmerge into 5.1 · 40e23984
      Patrick Crews authored
      40e23984
    • Patrick Crews's avatar
      Bug#37380 - Test funcs_1.is_columns_myisam_embedded fails on OS X · fbce395b
      Patrick Crews authored
      Test was failing due to the addition of a '\x05' character in result sets
      Latest builds of the server have shown this problem to have disappeared.
      Removing code within the test that disables the test on Mac OS X.
      
      Recommit due to tree error on earlier, approved patch.
      fbce395b
    • Mattias Jonsson's avatar
      Bug#36732: many disabled ndb tests in test suite parts · 01b7596c
      Mattias Jonsson authored
      REORGANIZE TEST parts WHERE ENGINE='NDB' ;)
      
      Updated tests for better matching NDB's limitations.
      
      Removed some duplicate tests.
      
      mysql-test/suite/parts/inc/part_supported_sql_funcs_delete.inc:
        Bug#36732: many disabled ndb tests in test suite parts
        
        Added variable for NDB (since it does not support
        DROP PARTITION)
      mysql-test/suite/parts/inc/partition_alter_11.inc:
        Bug#36732: many disabled ndb tests in test suite parts
        
        Assigning directly to variable without going
        through the server.
      mysql-test/suite/parts/inc/partition_bigint.inc:
        Bug#36732: many disabled ndb tests in test suite parts
        
        Added --sorted_result for consistency
        lowered number of partitions for use with NDB
        (NDB can only do maximum of 8 partitions)
      mysql-test/suite/parts/inc/partition_int.inc:
        Bug#36732: many disabled ndb tests in test suite parts
        
        Added --sorted_result for consistency
        lowered number of partitions for use with NDB
        (NDB can only do maximum of 8 partitions)
      mysql-test/suite/parts/inc/partition_mediumint.inc:
        Bug#36732: many disabled ndb tests in test suite parts
        
        Added --sorted_result for consistency
        lowered number of partitions for use with NDB
        (NDB can only do maximum of 8 partitions)
      mysql-test/suite/parts/inc/partition_smallint.inc:
        Bug#36732: many disabled ndb tests in test suite parts
        
        Added --sorted_result for consistency
        lowered number of partitions for use with NDB
        (NDB can only do maximum of 8 partitions)
      mysql-test/suite/parts/inc/partition_supported_sql_funcs.inc:
        Bug#36732: many disabled ndb tests in test suite parts
        
        Made it work better with NDB
      mysql-test/suite/parts/inc/partition_tinyint.inc:
        Bug#36732: many disabled ndb tests in test suite parts
        
        Added --sorted_result for consistency
        lowered number of partitions for use with NDB
        (NDB can only do maximum of 8 partitions)
      mysql-test/suite/parts/r/ndb_blob_partition.result:
        Bug#36732: many disabled ndb tests in test suite parts
        
        Removing this duplicate test since it already
        exists (and updated) in suite/ndb
      mysql-test/suite/parts/r/ndb_dd_backuprestore.result:
        Bug#36732: many disabled ndb tests in test suite parts
        
        Updated result file
      mysql-test/suite/parts/r/ndb_partition_error.result:
        Bug#36732: many disabled ndb tests in test suite parts
        
        Removing this duplicate test since it already
        exists (and updated) in suite/ndb
      mysql-test/suite/parts/r/ndb_partition_key.result:
        Bug#36732: many disabled ndb tests in test suite parts
        
        Removing this duplicate test since it already
        exists (and updated) in suite/ndb
      mysql-test/suite/parts/r/ndb_partition_list.result:
        Bug#36732: many disabled ndb tests in test suite parts
        
        Removing this duplicate test since it already
        exists (and updated) in suite/ndb
      mysql-test/suite/parts/r/ndb_partition_range.result:
        Bug#36732: many disabled ndb tests in test suite parts
        
        Removing this duplicate test since it already
        exists (and updated) in suite/ndb
      mysql-test/suite/parts/r/part_supported_sql_func_ndb.result:
        Bug#36732: many disabled ndb tests in test suite parts
        
        Updated result file
      mysql-test/suite/parts/r/partition_alter1_1_innodb.result:
        Bug#36732: many disabled ndb tests in test suite parts
        
        Updated result file
      mysql-test/suite/parts/r/partition_alter1_1_myisam.result:
        Bug#36732: many disabled ndb tests in test suite parts
        
        Updated result file
      mysql-test/suite/parts/r/partition_alter1_2_innodb.result:
        Bug#36732: many disabled ndb tests in test suite parts
        
        Updated result file.
        Diff bigger than necessary, due to bzr diff bug.
      mysql-test/suite/parts/r/partition_alter1_2_myisam.result:
        Bug#36732: many disabled ndb tests in test suite parts
        
        Updated result file
      mysql-test/suite/parts/r/partition_alter2_innodb.result:
        Bug#36732: many disabled ndb tests in test suite parts
        
        Updated result file
      mysql-test/suite/parts/r/partition_alter2_myisam.result:
        Bug#36732: many disabled ndb tests in test suite parts
        
        Updated result file
      mysql-test/suite/parts/r/partition_engine_ndb.result:
        Bug#36732: many disabled ndb tests in test suite parts
        
        Updated result file
      mysql-test/suite/parts/r/partition_int_innodb.result:
        Bug#36732: many disabled ndb tests in test suite parts
        
        Updated result file
      mysql-test/suite/parts/r/partition_int_myisam.result:
        Bug#36732: many disabled ndb tests in test suite parts
        
        Updated result file
      mysql-test/suite/parts/r/partition_int_ndb.result:
        Bug#36732: many disabled ndb tests in test suite parts
        
        Updated result file
      mysql-test/suite/parts/r/rpl_ndb_dd_partitions.result:
        Bug#36732: many disabled ndb tests in test suite parts
        
        Removing this duplicate test since it already
        exists (and updated) in suite/rpl_ndb
      mysql-test/suite/parts/t/disabled.def:
        Bug#36732: many disabled ndb tests in test suite parts
        
        Removed some duplicate tests, fixed some tests.
        Removed the 'runs too long on PB' test from
        disabled.def and made them to require 'big-test'.
      mysql-test/suite/parts/t/ndb_blob_partition.test:
        Bug#36732: many disabled ndb tests in test suite parts
        
        Removing this duplicate test since it already
        exists (and updated) in suite/ndb
      mysql-test/suite/parts/t/ndb_dd_backuprestore.test:
        Bug#36732: many disabled ndb tests in test suite parts
        
        Added new=on for allowing test of
        hash/range and list partitioning.
      mysql-test/suite/parts/t/ndb_partition_error.test:
        Bug#36732: many disabled ndb tests in test suite parts
        
        Removing this duplicate test since it already
        exists (and updated) in suite/ndb
      mysql-test/suite/parts/t/ndb_partition_key.test:
        Bug#36732: many disabled ndb tests in test suite parts
        
        Removing this duplicate test since it already
        exists (and updated) in suite/ndb
      mysql-test/suite/parts/t/ndb_partition_list.test:
        Bug#36732: many disabled ndb tests in test suite parts
        
        Removing this duplicate test since it already
        exists (and updated) in suite/ndb
      mysql-test/suite/parts/t/ndb_partition_range.test:
        Bug#36732: many disabled ndb tests in test suite parts
        
        Removing this duplicate test since it already
        exists (and updated) in suite/ndb
      mysql-test/suite/parts/t/part_supported_sql_func_ndb.test:
        Bug#36732: many disabled ndb tests in test suite parts
        
        Added new=on for allowing test of
        hash/range and list partitioning.
        Added ndb restriction variables.
      mysql-test/suite/parts/t/partition_alter1_1_2_ndb.test:
        Bug#36732: many disabled ndb tests in test suite parts
        
        requiring big-test instead of disable it.
      mysql-test/suite/parts/t/partition_alter1_1_ndb.test:
        Bug#36732: many disabled ndb tests in test suite parts
        
        requiring big-test instead of disable it.
      mysql-test/suite/parts/t/partition_alter1_2_ndb.test:
        Bug#36732: many disabled ndb tests in test suite parts
        
        requiring big-test instead of disable it.
      mysql-test/suite/parts/t/partition_alter2_ndb.test:
        Bug#36732: many disabled ndb tests in test suite parts
        
        Added new=on for allowing test of
        hash/range and list partitioning.
      mysql-test/suite/parts/t/partition_basic_ndb.test:
        Bug#36732: many disabled ndb tests in test suite parts
        
        Added new=on for allowing test of
        hash/range and list partitioning.
      mysql-test/suite/parts/t/partition_bit_ndb.test:
        Bug#36732: many disabled ndb tests in test suite parts
        
        Added new=on for allowing test of
        hash/range and list partitioning.
      mysql-test/suite/parts/t/partition_engine_ndb.test:
        Bug#36732: many disabled ndb tests in test suite parts
        
        Added new=on for allowing test of
        hash/range and list partitioning.
      mysql-test/suite/parts/t/partition_int_ndb.test:
        Bug#36732: many disabled ndb tests in test suite parts
        
        Added new=on for allowing test of
        hash/range and list partitioning.
      mysql-test/suite/parts/t/partition_syntax_ndb.test:
        Bug#36732: many disabled ndb tests in test suite parts
        
        Added new=on for allowing test of
        hash/range and list partitioning.
      mysql-test/suite/parts/t/partition_value_ndb.test:
        Bug#36732: many disabled ndb tests in test suite parts
        
        Added new=on for allowing test of
        hash/range and list partitioning.
      mysql-test/suite/parts/t/rpl_ndb_dd_partitions.test:
        Bug#36732: many disabled ndb tests in test suite parts
        
        Removing this duplicate test since it already
        exists (and updated) in suite/rpl_ndb
      01b7596c
  7. 30 Jun, 2008 1 commit
    • Sven Sandberg's avatar
      BUG#37200: rpl_switch_stm_row_mixed fails sporadically in pushbuild · 0bf02129
      Sven Sandberg authored
      Problem: rpl_switch_stm_row_mixed did not wait until row events generated by
      INSERT DELAYED were written to the master binlog before it synchronized slave
      with master. This caused sporadic errors where these rows were missing on
      slave.
      Fix: wait until all rows appear on the slave.
      This is a backport, applying the same to 5.1-bugteam as was previously
      applied to 6.0-rpl
      0bf02129
  8. 27 Jun, 2008 8 commits
    • Timothy Smith's avatar
      237a65cc
    • Timothy Smith's avatar
      Merge from upstream (my:5.0-bugteam) · 81183252
      Timothy Smith authored
      81183252
    • Timothy Smith's avatar
      Up-merge from 5.0: Fix for Bug#20748, Configuration files should not be read more than once · cb18b447
      Timothy Smith authored
      Differences in 5.1: include "/etc/mysql/" in include directories; no OS/2 support.
      cb18b447
    • Gleb Shchepa's avatar
      auto merge from local tree · 918efba1
      Gleb Shchepa authored
      918efba1
    • Gleb Shchepa's avatar
      Fixed bug #36632: SELECT DISTINCT from a simple view on an · b9c7cb32
      Gleb Shchepa authored
                        InnoDB table, where all selected columns
                        belong to the same unique index key, returns
                        incorrect results
      
      Server executes some queries via QUICK_GROUP_MIN_MAX_SELECT
      (MIN/MAX optimization for queries with GROUP BY or DISTINCT
      clause) and that optimization implies loose index scan, so all
      grouping is done by the QUICK_GROUP_MIN_MAX_SELECT::get_next
      method.
      
      The server does not set the precomputed_group_by flag for some
      QUICK_GROUP_MIN_MAX_SELECT queries and duplicates grouping by
      call to the end_send_group function.
      
      Fix: when the test_if_skip_sort_order function selects loose 
      index scan as a best way to satisfy an ORDER BY/GROUP BY type
      of query, the precomputed_group_by flag has been set to use 
      end_send/end_write functions instead of end_send_group/
      end_write_group functions.
      
      
      mysql-test/r/group_min_max_innodb.result:
        Fixed bug #36632: SELECT DISTINCT from a simple view on an
                          InnoDB table, where all selected columns
                          belong to the same unique index key, returns
                          incorrect results
      mysql-test/t/group_min_max_innodb.test:
        Fixed bug #36632: SELECT DISTINCT from a simple view on an
                          InnoDB table, where all selected columns
                          belong to the same unique index key, returns
                          incorrect results
      sql/sql_select.cc:
        Fixed bug #36632: SELECT DISTINCT from a simple view on an
                          InnoDB table, where all selected columns
                          belong to the same unique index key, returns
                          incorrect results
      b9c7cb32
    • Gleb Shchepa's avatar
      merge 5.0-bugteam --> 5.1-bugteam · 5ef645e5
      Gleb Shchepa authored
      5ef645e5
    • Gleb Shchepa's avatar
      backport from 6.0 · 4e9d0160
      Gleb Shchepa authored
            
      Bug#35658 (An empty binary value leads to mysqld crash)
              
      Before this fix, the following token
        b''
      caused the parser to crash when reading the binary value from the empty string.
      The crash was caused by:
        ptr+= max_length - 1;
      because max_length is unsigned and was 0, causing an overflow.
              
      With this fix, an empty binary literal b'' is parsed as a binary value 0,
      in Item_bin_string.
      
      mysql-test/r/varbinary.result:
        Bug#35658 (An empty binary value leads to mysqld crash)
      mysql-test/t/varbinary.test:
        Bug#35658 (An empty binary value leads to mysqld crash)
      sql/item.cc:
        Bug#35658 (An empty binary value leads to mysqld crash)
      4e9d0160
    • Gleb Shchepa's avatar
      backport to 5.1 from 6.0 · 4b8e4637
      Gleb Shchepa authored
      Bug#35658 (An empty binary value leads to mysqld crash)
        
      Before this fix, the following token
        b''
      caused the parser to crash when reading the binary value from the empty string.
      The crash was caused by:
        ptr+= max_length - 1;
      because max_length is unsigned and was 0, causing an overflow.
        
      With this fix, an empty binary literal b'' is parsed as a binary value 0,
      in Item_bin_string.
      
      mysql-test/r/varbinary.result:
        Bug#35658 (An empty binary value leads to mysqld crash)
      mysql-test/t/varbinary.test:
        Bug#35658 (An empty binary value leads to mysqld crash)
      sql/item.cc:
        Bug#35658 (An empty binary value leads to mysqld crash)
      4b8e4637
  9. 25 Jun, 2008 4 commits
    • Matthias Leich's avatar
      Upmerge 5.0 -> 5.1 · 3975d9cd
      Matthias Leich authored
      3975d9cd
    • Matthias Leich's avatar
      Fix for · fbb3f400
      Matthias Leich authored
      Bug#37492 timing bug in subselect.test
      + similar weaknesses found during testing
      + replace error numbers by error names
      fbb3f400
    • Gleb Shchepa's avatar
      auto merge 5.1-main --> 5.1-bugteam · 3bd6ca94
      Gleb Shchepa authored
      3bd6ca94
    • Timothy Smith's avatar
      Bug #20748: Configuration files should not be read more than once · bbe19e13
      Timothy Smith authored
      Normalize directory names before adding them to default_directories.
      
      
      mysys/default.c:
        Normalize directory names with unpack_dirname() before adding them
        to default_directories.  This way, /etc/ and /etc will not count as
        duplicates.
        
        Because this entails allocating memory to store the normalized names,
        add error handling and ensure that it doesn't leak memory in case
        both my_print_defaults() and load_defaults() are called.
        
        Clean up the Windows code that finds the exe's parent directory, and
        pull it out into a separate function.
        
        Reorganize the code into a single init_default_directories() function,
        with internal #ifdefs, instead of init_default_directories_<system>()
        functions which were accessed via a function pointer.  This is more in
        line with normal MySQL coding style, and easier to read for some.
      bbe19e13
  10. 24 Jun, 2008 2 commits