|
|
|
| Такой код:
// Старт транзакции
mysql_query("START TRANSACTION");
$sql1 = "UPDATE tbl1 SET val = 500 WHERE id_user = 1";
$query1 = mysql_query($sql1);
if(!$query1)
{
mysql_query("ROLLBACK"); // Откатка 1
}
$sql2 = "UPDATE tbl2 SET val = 300 WHERE id_user = 1";
$query2 = mysql_query($sql2);
if(!$query2)
{
mysql_query("ROLLBACK"); // Откатка 2
}
mysql_query("COMMIT"); // Запись
|
Вопрос 1. Что будет если по каким-то причинам времено откажет сервер MySQL и последний запрос COMMIT не будет выполнен?
Вопрос 2. Что будет если последнего запроса вообще не будет. А скрипт просто завершит работу. Будет ли произведена запись в БД или нет? | |
|
|