The slave checks for and evaluates table options only if no matching database options were found (see Section 16.4.3.1, “Evaluation of Database-Level Replication and Binary Logging Options”).
First, as a preliminary condition, the slave checks whether statement-based replication is enabled. If so, and the statement occurs within a stored function, the slave executes the statement and exits. (If row-based replication is enabled, the slave does not know whether a statement occurred within a stored function on the master, so this condition does not apply.)
Recall that for statement-based replication, replication
events represent statements (all changes making up a given
event are associated with a single SQL statement); for
row-based replication, each event represents a change in a
single table row (thus a single statement such as
UPDATE mytable SET mycol = 1
may yield many
row-based events). When viewed in terms of events, the process
of checking table options is the same for both row-based and
statement-based replication.
Having reached this point, if there are no table options, the
slave simply executes all events. If there are any
--replicate-do-table
or
--replicate-wild-do-table
options, the event must match one these if it is to be executed;
otherwise, it is ignored. If there are any
--replicate-ignore-table
or
--replicate-wild-ignore-table
options, all events are executed except those that match any of
these options. This process is illustrated in the following
diagram:
The following steps describe this evaluation in more detail:
Are there any table options?
Yes. Continue to step 2.
No. Execute the event and exit.
Are there any
--replicate-do-table
options?
Yes. Does the table match any of them?
Yes. Execute the event and exit.
No. Continue to step 3.
No. Continue to step 3.
Are there any
--replicate-ignore-table
options?
Yes. Does the table match any of them?
Yes. Ignore the event and exit.
No. Continue to step 4.
No. Continue to step 4.
Are there any
--replicate-wild-do-table
options?
Yes. Does the table match any of them?
Yes. Execute the event and exit.
No. Continue to step 5.
No. Continue to step 5.
Are there any
--replicate-ignore-table
options?
Yes. Does the table match any of them?
Yes. Ignore the event and exit.
No. Continue to step 6.
No. Continue to step 6.
Are there any
--replicate-do-table
or
--replicate-wild-do-table
options?
Yes. Ignore the event and exit.
No. Execute the event and exit.
User Comments
Add your own comment.