stop slave; drop table if exists t1,t2,t3,t4,t5,t6,t7,t8,t9; reset master; reset slave; drop table if exists t1,t2,t3,t4,t5,t6,t7,t8,t9; start slave; DROP PROCEDURE IF EXISTS test.p1; DROP TABLE IF EXISTS test.t1; CREATE PROCEDURE test.p1(IN i INT) BEGIN DECLARE CONTINUE HANDLER FOR sqlexception BEGIN END; DROP TABLE IF EXISTS test.t1; CREATE TABLE test.t1 (num INT,PRIMARY KEY(num))ENGINE=INNODB; START TRANSACTION; INSERT INTO test.t1 VALUES(i); savepoint t1_save; INSERT INTO test.t1 VALUES (14); ROLLBACK to savepoint t1_save; COMMIT; END| < ---- Master selects-- > ------------------------- CALL test.p1(12); SELECT * FROM test.t1; num 12 < ---- Slave selects-- > ------------------------ SELECT * FROM test.t1; num 12 < ---- Master selects-- > ------------------------- CALL test.p1(13); SELECT * FROM test.t1; num 13 < ---- Slave selects-- > ------------------------ SELECT * FROM test.t1; num 13 DROP PROCEDURE IF EXISTS test.p1; DROP TABLE IF EXISTS test.t1;