У меня есть код, который использовался в приложении, где у меня возникла проблема с откатом. Даже если I 's2' возвращает ложный откат не происходит, то есть таблица 'products' отбрасывается.
Может кто-нибудь объяснить, почему это не работает или как я должен изменить это.
Примечание: таблицы из движка Innodb. Я использую mysql 5.0+
mysql_query('SET AUTOCOMMIT=0;');
mysql_query('START TRANSACTION;');
$sql = 'DROP TABLE '.$this->Product->tablePrefix.'products';
$s1 = mysql_query($sql);
$sql = 'RENAME TABLE '.$this->Product->tablePrefix.'temp12212 TO '.$this->Product->tablePrefix.'products';
$s2 =mysql_query($sql);
if($s1 && $s2){
mysql_query('COMMIT;');
$this->Session->setFlash('Commit Successful to Database');
}else{
mysql_query('ROLLBACK;');
$this->Session->setFlash('Commit failed due to some errors<br> auto-rollbacked to previous state');
}