unknown
a914b5274f
Save and clear run context before executing a stored function or trigger and restore it afterwards.
...
This allows us to use statement replication with functions and triggers
The following things are fixed with this patch:
- NOW() and automatic timestamps takes the value from the main event for functions and triggers (which allows these to replicate with statement level logging)
- No side effects for triggers or functions with auto-increment values(), last_insert_id(), rand() or found_rows()
- Triggers can't return result sets
Fixes bugs:
#12480 : NOW() is not constant in a trigger
#12481 : Using NOW() in a stored function breaks statement based replication
#12482 : Triggers has side effects with auto_increment values
#11587 : trigger causes lost connection error
mysql-test/r/trigger.result:
Added test fpr big
mysql-test/t/sp-error.test:
Changed error message numbers
mysql-test/t/trigger.test:
Added test for trigger returning result (#11587 )
sql/item_func.cc:
Store the first used seed value for RAND() value.
(This makes rand() replicatable in functions and triggers)
Save and clear run context before executing a stored function and restore it afterwards.
This removes side effects of stored functions for RAND(), auto-increment values and NOW() and makes most stored function replicatable
sql/share/errmsg.txt:
Reuse error message also for triggers
sql/sp_head.cc:
If in function or trigger, don't change value of NOW()
(This allows us to use statement replication with functions that directly or indirectly uses timestamps)
sql/sql_class.cc:
Added framework for storing and retrieving run context while exceuting triggers or stored functions.
sql/sql_class.h:
Added framework for storing and retrieving run context while exceuting triggers or stored functions.
sql/sql_parse.cc:
If in function or trigger, don't change value of NOW()
(This allows us to use statement replication with functions that directly or indirectly uses timestamps)
sql/sql_trigger.cc:
Moved process_triggers function from sql_trigger.h
Use reset/restore sub_statement_state while executing triggers to avoid side effects and make them replicatable
sql/sql_trigger.h:
Moved process_triggers function from sql_trigger.h
Use reset/restore sub_statement_state while executing triggers to avoid side effects and make them replicatable
sql/sql_yacc.yy:
Give error message if trigger can return a result set (Bug #11587 )
tests/fork_big2.pl:
Removed return from end of lines
mysql-test/r/rpl_trigger.result:
New BitKeeper file ``mysql-test/r/rpl_trigger.result''
mysql-test/t/rpl_trigger.test:
New BitKeeper file ``mysql-test/t/rpl_trigger.test''
2005-08-15 18:15:12 +03:00
..
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-08-11 12:18:53 +01:00
2005-07-28 03:22:47 +03:00
2005-02-23 20:35:59 +01:00
2005-03-16 23:12:27 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 17:09:54 +03:00
2005-04-04 12:43:58 -07:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-08-03 07:29:48 +02:00
2005-07-28 03:22:47 +03:00
2005-08-02 14:27:52 +05:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-18 13:38:56 -07:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 17:09:54 +03:00
2005-06-01 17:36:21 +02:00
2005-08-01 17:00:03 -07:00
2005-07-28 17:09:54 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-07-31 21:33:46 +02:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-08-08 11:42:09 -07:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-19 03:04:51 +02:00
2005-07-28 17:09:54 +03:00
2005-04-04 12:43:58 -07:00
2005-08-03 02:01:27 +04:00
2005-08-08 00:10:07 +02:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-08-07 21:30:46 +00:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-08-02 12:09:49 -07:00
2005-07-28 17:09:54 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 21:29:45 -07:00
2005-07-28 17:09:54 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-08-01 17:54:57 -07:00
2005-08-11 18:58:22 -07:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 17:09:54 +03:00
2005-08-11 12:18:53 +01:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-08-05 20:26:55 +05:00
2005-07-28 17:09:54 +03:00
2005-03-22 15:57:24 +02:00
2005-04-04 12:43:58 -07:00
2005-07-28 17:09:54 +03:00
2005-08-08 19:04:10 +05:00
2005-08-07 22:10:05 +00:00
2005-06-14 12:52:44 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 17:09:54 +03:00
2005-08-09 11:21:45 +03:00
2005-07-28 03:22:47 +03:00
2005-06-20 08:56:37 +00:00
2005-02-22 18:30:44 +03:00
2005-05-16 13:34:23 +03:00
2005-06-20 11:05:38 +02:00
2005-05-24 14:35:23 +04:00
2005-05-20 16:39:28 +04:00
2005-08-09 11:43:55 +04:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-04-07 19:24:14 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-08-09 22:05:07 +04:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-08-10 22:17:53 +01:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-08-05 16:43:35 -07:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-08-07 20:39:17 +02:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-08-02 15:58:41 -07:00
2005-02-15 13:36:46 -08:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-03-28 15:13:31 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-02-17 11:48:44 -08:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-08-04 16:36:14 +05:00
2005-07-28 03:22:47 +03:00
2005-05-17 21:14:01 +02:00
2005-07-28 03:22:47 +03:00
2005-06-03 15:29:05 +02:00
2005-07-28 17:09:54 +03:00
2005-07-28 17:09:54 +03:00
2005-07-29 23:43:07 +03:00
2005-04-04 12:43:58 -07:00
2005-07-31 12:49:55 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 17:09:54 +03:00
2005-04-21 11:11:37 +02:00
2005-07-28 03:22:47 +03:00
2005-04-21 11:11:37 +02:00
2005-04-21 11:11:37 +02:00
2005-04-21 11:11:37 +02:00
2005-07-28 17:09:54 +03:00
2005-07-28 17:09:54 +03:00
2005-06-01 11:56:47 +02:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-04-21 11:11:37 +02:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-31 04:29:34 -07:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-08-03 17:38:55 -07:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-08-11 13:07:08 +03:00
2005-08-07 21:30:46 +00:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 17:09:54 +03:00
2005-03-02 11:29:48 +01:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 21:25:05 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-08-07 21:30:46 +00:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-08-11 17:14:11 -07:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-04-01 15:04:50 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-08-03 15:08:03 -04:00
2005-05-05 14:20:53 +02:00
2005-05-05 14:20:53 +02:00
2005-07-19 20:06:49 +04:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-03-22 00:26:12 +01:00
2005-07-28 17:09:54 +03:00
2005-08-15 18:15:12 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 17:09:54 +03:00
2005-05-07 06:55:47 -07:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-07-29 09:25:11 -07:00
2005-07-28 17:09:54 +03:00
2005-07-28 17:09:54 +03:00
2005-05-26 16:44:46 +02:00
2005-05-26 16:44:46 +02:00
2005-07-28 03:22:47 +03:00
2005-06-07 16:48:38 +02:00
2005-07-26 18:08:49 -07:00
2005-08-15 18:15:12 +03:00
2005-07-01 15:25:51 +02:00
2005-08-03 03:37:32 +00:00
2005-08-03 03:37:32 +00:00
2005-08-10 21:17:52 +00:00
2005-08-11 16:43:22 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-07-27 15:09:06 +05:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-08-11 12:18:53 +01:00
2005-04-07 19:24:14 +03:00
2005-04-07 19:24:14 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-03-01 19:05:48 -08:00
2005-07-28 17:09:54 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-08-15 18:15:12 +03:00
2005-07-28 03:22:47 +03:00
2005-08-08 11:42:09 -07:00
2005-08-10 21:17:52 +00:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-08-09 00:13:49 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-07-29 14:39:11 +05:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 03:22:47 +03:00
2005-05-25 18:11:47 -07:00
2005-07-28 03:22:47 +03:00
2005-07-28 17:09:54 +03:00
2005-07-28 17:09:54 +03:00
2005-04-04 12:43:58 -07:00
2005-07-28 17:09:54 +03:00
2005-08-01 17:54:57 -07:00
2005-07-28 03:22:47 +03:00
2005-07-31 12:56:02 +03:00
2005-07-05 13:36:36 +03:00
2005-08-12 01:27:04 -07:00
2005-07-28 17:09:54 +03:00
2005-04-05 13:17:49 +02:00