Commit b892f50e authored by Vasil Dimov's avatar Vasil Dimov

Replay 2661.581.1 and 3092.5.1 on top of storage/innobase.

  ------------------------------------------------------------
  revno: 2661.581.1
  revision-id: sven.sandberg@sun.com-20090714193119-4693witmsqcaf28q
  parent: staale.smedseng@sun.com-20090615160325-miaxz8z9rjgm78h4
  committer: Sven Sandberg <sven.sandberg@sun.com>
  branch nick: 5.1-bugteam
  timestamp: Tue 2009-07-14 21:31:19 +0200
  message:
    BUG#39934: Slave stops for engine that only support row-based logging
  ...


  ------------------------------------------------------------
  revno: 3092.5.1
  revision-id: luis.soares@sun.com-20090924145252-8vvsnbvwo9l8v4vc
  parent: anurag.shekhar@sun.com-20090831075609-tkpqu41hxtupdeip
  committer: Luis Soares <luis.soares@sun.com>
  branch nick: mysql-5.1-bugteam
  timestamp: Thu 2009-09-24 15:52:52 +0100
  message:
    BUG#42829: binlogging enabled for all schemas regardless of
    binlog-db-db / binlog-ignore-db
  ...
parent 94b6b2b9
...@@ -8567,25 +8567,21 @@ ha_innobase::external_lock( ...@@ -8567,25 +8567,21 @@ ha_innobase::external_lock(
/* Statement based binlogging does not work in isolation level /* Statement based binlogging does not work in isolation level
READ UNCOMMITTED and READ COMMITTED since the necessary READ UNCOMMITTED and READ COMMITTED since the necessary
locks cannot be taken. In this case, we print an locks cannot be taken. In this case, we print an
informative error message and return with an error. */ informative error message and return with an error.
if (lock_type == F_WRLCK) Note: decide_logging_format would give the same error message,
{ except it cannot give the extra details. */
ulong const binlog_format= thd_binlog_format(thd); if (lock_type == F_WRLCK
ulong const tx_isolation = thd_tx_isolation(ha_thd()); && !(table_flags() & HA_BINLOG_STMT_CAPABLE)
if (tx_isolation <= ISO_READ_COMMITTED && thd_binlog_format(thd) == BINLOG_FORMAT_STMT
&& binlog_format == BINLOG_FORMAT_STMT && thd_binlog_filter_ok(thd)) {
#if MYSQL_VERSION_ID > 50140 int skip = 0;
&& thd_binlog_filter_ok(thd) /* used by test case */
#endif /* MYSQL_VERSION_ID > 50140 */ DBUG_EXECUTE_IF("no_innodb_binlog_errors", skip = 1;);
) if (!skip) {
{ my_error(ER_BINLOG_STMT_MODE_AND_ROW_ENGINE, MYF(0),
char buf[256]; " InnoDB is limited to row-logging when "
my_snprintf(buf, sizeof(buf), "transaction isolation level is "
"Transaction level '%s' in" "READ COMMITTED or READ UNCOMMITTED.");
" InnoDB is not safe for binlog mode '%s'",
tx_isolation_names[tx_isolation],
binlog_format_names[binlog_format]);
my_error(ER_BINLOG_LOGGING_IMPOSSIBLE, MYF(0), buf);
DBUG_RETURN(HA_ERR_LOGGING_IMPOSSIBLE); DBUG_RETURN(HA_ERR_LOGGING_IMPOSSIBLE);
} }
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment