Форум: Форум PHPФорум ApacheФорум Регулярные ВыраженияФорум MySQLHTML+CSS+JavaScriptФорум FlashРазное
Новые темы: 0000000
Самоучитель PHP 5 / 6 (3 издание). Авторы: Кузнецов М.В., Симдянов И.В. Самоучитель MySQL 5. Авторы: Кузнецов М.В., Симдянов И.В. PHP 5. На примерах. Авторы: Кузнецов М.В., Симдянов И.В., Голышев С.В. MySQL на примерах. Авторы: Кузнецов М.В., Симдянов И.В. Социальная инженерия и социальные хакеры. Авторы: Кузнецов М.В., Симдянов И.В.
ВСЕ НАШИ КНИГИ
Консультационный центр SoftTime

Форум MySQL

Выбрать другой форум

 

Здравствуйте, Посетитель!

вид форума:
Линейный форум Структурный форум

тема: много запросов к базе
 
 автор: Дмитрий Смаль   (06.05.2009 в 16:38)   письмо автору
 
 

Здравствуйте!
такой вопрос

после регистрации пользователя нужно сделать много запросов к бд (inset i update) но с таким условием, что либо все запросы должны произойти, либо если хоть один даёт сбой, то ничего не изменяется
то-есть в результате изменения должны произойти во все указанные таблицы либо вообще не произойти и вывести сообщение об ошибке

если кто знает решение на php, то буд очень признателен

сейчас меня так:
$query = "UPDATE ... SET... WHERE ..";
$result = mysql_query ($query);
if (mysql_affected_rows() == 1) {$massage.= "..";} else {$massage.=$eror;}
$query = "INSERT INTO ... VALUES ...";
$result = mysql_query ($query);
if (mysql_affected_rows() == 1) {$massage.= "..";} else {$massage.=$eror;}
$query = "UPDATE .. SET .. WHERE..'";
$result = mysql_query ($query);
if (mysql_affected_rows() == 1) {$massage .= "...";} else {$massage.="...";}

и так далее, всего может быть от 3 до 20 запросов в разных комбинациях
если хотя бы один запрос даст сбой, то вся работа до жопы
приходится блокировать систему и в ручном режиме править из пхпмайадмин

  Ответить  
 
 автор: Trianon   (06.05.2009 в 17:18)   письмо автору
 
   для: Дмитрий Смаль   (06.05.2009 в 16:38)
 

транзакции в MySQL реализованы на таблицах вида InnoDB

  Ответить  
Rambler's Top100
вверх

Rambler's Top100 Яндекс.Метрика Яндекс цитирования