1. 19 Dec, 2003 21 commits
  2. 18 Dec, 2003 15 commits
    • sergefp@mysql.com's avatar
      Post-merge fixes and code cleanup · 50f29b0e
      sergefp@mysql.com authored
      50f29b0e
    • pem@mysql.comhem.se's avatar
      Post-merge fix. · 89b2ddcf
      pem@mysql.comhem.se authored
      89b2ddcf
    • pem@mysql.com's avatar
      Merge · 7b13840a
      pem@mysql.com authored
      7b13840a
    • pem@mysql.comhem.se's avatar
    • monty@mysql.com's avatar
    • hf@deer.(none)'s avatar
      Merge abotchkov@bk-internal.mysql.com:/home/bk/mysql-4.1 · 7c3ee999
      hf@deer.(none) authored
      into deer.(none):/home/hf/work/mysql-4.1.2126
      7c3ee999
    • hf@deer.(none)'s avatar
      Fix for #2126 · de470e6f
      hf@deer.(none) authored
      additional changes (after discussion with Monty)
      de470e6f
    • psergey@psergey-rh8.(none)'s avatar
      Merge psergey-rh8.(none):/home/psergey/mysql-5.0-latest-pull · b1f07034
      psergey@psergey-rh8.(none) authored
      into psergey-rh8.(none):/home/psergey/mysql-5.0-imerge-unique
      b1f07034
    • monty@mysql.com's avatar
      Removed compiler warning · 1f997d4a
      monty@mysql.com authored
      Fixed not updated test from last changeset
      1f997d4a
    • monty@mysql.com's avatar
      Simple cleanups · b9d8f108
      monty@mysql.com authored
      b9d8f108
    • jani@rhols221.arenanet.fi's avatar
    • hf@deer.(none)'s avatar
      Fix for #2126 (mysql_server_init call shouldn't be needed) · 42799cc5
      hf@deer.(none) authored
      now mysql_server_init is called from mysql_init with fake parameters
      mysql_once_init code included to mysql_server_init.
      embedded-specific initialization is in init_embedded_server function
      42799cc5
    • sergefp@mysql.com's avatar
      67c6d511
    • guilhem@mysql.com's avatar
      Merge gbichot@bk-internal.mysql.com:/home/bk/mysql-5.0 · 2f3c1efa
      guilhem@mysql.com authored
      into mysql.com:/home/mysql_src/mysql-5.0-new-binlog-format
      2f3c1efa
    • guilhem@gbichot2's avatar
      This will be pushed only after I fix the testsuite. · 66a32e89
      guilhem@gbichot2 authored
      This is the main commit for Worklog tasks:
       * A more dynamic binlog format which allows small changes (1064)
       * Log session variables in Query_log_event (1063)
      Below 5.0 means 5.0.0.
      MySQL 5.0 is able to replicate FOREIGN_KEY_CHECKS, UNIQUE_KEY_CHECKS (for speed),
      SQL_AUTO_IS_NULL, SQL_MODE. Not charsets (WL#1062), not some vars (I can only think
      of SQL_SELECT_LIMIT, which deserves a special treatment). Note that this
      works for queries, except LOAD DATA INFILE (for this it would have to wait
      for Dmitri's push of WL#874, which in turns waits for the present push, so...
      the deadlock must be broken!). Note that when Dmitri pushes WL#874 in 5.0.1,
      5.0.0 won't be able to replicate a LOAD DATA INFILE from 5.0.1.
      Apart from that, the new binlog format is designed so that it can tolerate
      a little variation in the events (so that a 5.0.0 slave could replicate a
      5.0.1 master, except for LOAD DATA INFILE unfortunately); that is, when I
      later add replication of charsets it should break nothing. And when I later
      add a UID to every event, it should break nothing.
      The main change brought by this patch is a new type of event, Format_description_log_event,
      which describes some lengthes in other event types. This event is needed for
      the master/slave/mysqlbinlog to understand a 5.0 log. Thanks to this event,
      we can later add more bytes to the header of every event without breaking compatibility.
      Inside Query_log_event, we have some additional dynamic format, as every Query_log_event
      can have a different number of status variables, stored as pairs (code, value); that's
      how SQL_MODE and session variables and catalog are stored. Like this, we can later
      add count of affected rows, charsets... and we can have options --don't-log-count-affected-rows
      if we want.
      MySQL 5.0 is able to run on 4.x relay logs, 4.x binlogs.
      Upgrading a 4.x master to 5.0 is ok (no need to delete binlogs),
      upgrading a 4.x slave to 5.0 is ok (no need to delete relay logs);
      so both can be "hot" upgrades.
      Upgrading a 3.23 master to 5.0 requires as much as upgrading it to 4.0.
      3.23 and 4.x can't be slaves of 5.0.
      So downgrading from 5.0 to 4.x may be complicated.
      Log_event::log_pos is now the position of the end of the event, which is
      more useful than the position of the beginning. We take care about compatibility
      with <5.0 (in which log_pos is the beginning).
      I added a short test for replication of SQL_MODE and some other variables.
      TODO:
      - after committing this, merge the latest 5.0 into it
      - fix all tests
      - update the manual with upgrade notes.
      66a32e89
  3. 17 Dec, 2003 4 commits