Binary Logging of Stored Programs
1712
| 14 |
+--------+
NAME_CONST()
[967]
enables a logged standalone statement to be executed on a slave with the
same effect as the original statement that was executed on the master within a stored procedure.
The use of
NAME_CONST()
[967]
can result in a problem for
CREATE TABLE ... SELECT
statements when the source column expressions refer to local variables. Converting these
references to
NAME_CONST()
[967]
expressions can result in column names that are different
on the master and slave servers, or names that are too long to be legal column identifiers. A
workaround is to supply aliases for columns that refer to local variables. Consider this statement
when
myvar
has a value of 1:
CREATE TABLE t1 SELECT myvar;
That will be rewritten as follows:
CREATE TABLE t1 SELECT NAME_CONST(myvar, 1);
To ensure that the master and slave tables have the same column names, write the statement like
this:
CREATE TABLE t1 SELECT myvar AS myvar;
The rewritten statement becomes:
CREATE TABLE t1 SELECT NAME_CONST(myvar, 1) AS myvar;
• A statement to be logged might contain references to user-defined variables. To handle this,
MySQL writes a
SET
statement to the binary log to make sure that the variable exists on the slave
with the same value as on the master. For example, if a statement refers to a variable
@my_var
,
that statement will be preceded in the binary log by the following statement, where
value
is the
value of
@my_var
on the master:
SET @my_var =
value
;
• Procedure calls can occur within a committed or rolled-back transaction. Previously,
CALL
statements were logged even if they occurred within a rolled-back transaction. As of MySQL
5.0.12, transactional context is accounted for so that the transactional aspects of procedure
execution are replicated correctly. That is, the server logs those statements within the procedure
that actually execute and modify data, and also logs
BEGIN
,
COMMIT
, and
ROLLBACK
statements
as necessary. For example, if a procedure updates only transactional tables and is executed
within a transaction that is rolled back, those updates are not logged. If the procedure occurs
within a committed transaction,
BEGIN
and
COMMIT
statements are logged with the updates. For a
procedure that executes within a rolled-back transaction, its statements are logged using the same
rules that would apply if the statements were executed in standalone fashion:
• Updates to transactional tables are not logged.
• Updates to nontransactional tables are logged because rollback does not cancel them.
• Updates to a mix of transactional and nontransactional tables are logged surrounded by
BEGIN
and
ROLLBACK
so that slaves will make the same changes and rollbacks as on the master.
• A stored procedure call is not written to the binary log at the statement level if the procedure is
invoked from within a stored function. In that case, the only thing logged is the statement that invokes
the function (if it occurs within a statement that is logged) or a
DO
statement (if it occurs within a
statement that is not logged). For this reason, care still should be exercised in the use of stored
functions that invoke a procedure, even if the procedure is otherwise safe in itself.
Содержание 5.0
Страница 1: ...MySQL 5 0 Reference Manual ...
Страница 18: ...xviii ...
Страница 60: ...40 ...
Страница 396: ...376 ...
Страница 578: ...558 ...
Страница 636: ...616 ...
Страница 844: ...824 ...
Страница 1234: ...1214 ...
Страница 1426: ...MySQL Proxy Scripting 1406 The following diagram shows an overview of the classes exposed by MySQL Proxy ...
Страница 1427: ...MySQL Proxy Scripting 1407 ...
Страница 1734: ...1714 ...
Страница 1752: ...1732 ...
Страница 1783: ...Configuring Connector ODBC 1763 ...
Страница 1793: ...Connector ODBC Examples 1773 ...
Страница 1839: ...Connector Net Installation 1819 2 You must choose the type of installation to perform ...
Страница 1842: ...Connector Net Installation 1822 5 Once the installation has been completed click Finish to exit the installer ...
Страница 1864: ...Connector Net Visual Studio Integration 1844 Figure 20 24 Debug Stepping Figure 20 25 Function Stepping 1 of 2 ...
Страница 2850: ...2830 ...
Страница 2854: ...2834 ...
Страница 2928: ...2908 ...
Страница 3000: ...2980 ...
Страница 3122: ...3102 ...
Страница 3126: ...3106 ...
Страница 3174: ...3154 ...
Страница 3232: ...3212 ...