Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: Транзакция РНР MySQL

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


 Страниц (1): [1]   

> Без описания
ruslanaxti
Отправлено: 16 Марта, 2015 - 10:40:59
Post Id


Новичок


Покинул форум
Сообщений всего: 17
Дата рег-ции: Окт. 2014  


Помог: 0 раз(а)




Написал вот такую транзакцию

PHP:
скопировать код в буфер обмена
  1.  
  2. mysqli_query(mysqlconnect(),"SET AUTOCOMMIT=0");
  3. mysqli_query(mysqlconnect(),'START TRANSACTION');
  4.                                
  5.        $q1 = mysqli_query(mysqlconnect(), "UPDATE );
  6.       $q2 = mysqli_query(mysqlconnect(), "INSERT  );
  7.        
  8.                                                        
  9.  if ($q1 and $q2) {
  10.                                
  11.        mysqli_query(mysqlconnect(),"COMMIT");
  12. }
  13.  


После запросов $q1 и $q2 правильно ли будет проверить if (условие, запрос выполнен) делать COMMIT или его писать сразу не использую if ?

Заранее спасибо!
 
 Top
DeepVarvar Супермодератор
Отправлено: 16 Марта, 2015 - 11:07:33
Post Id



Активный участник


Покинул форум
Сообщений всего: 10377
Дата рег-ции: Дек. 2008  
Откуда: Альфа Центавра


Помог: 353 раз(а)




Чот я забыл насчет майскулИ, есть ли там как в ПДО PDO::ERRMODE_EXCEPTION, но принцип такой:

(опять поломали бб-ссылки?)
CODE (text):
скопировать код в буфер обмена
  1. https://github.com/Romandry/phpsu/blob/master/application/core/DBC.php#L112


Если хоть один не прошел, то сразу можно роллбечить предыдущие.
 
 Top
ruslanaxti
Отправлено: 16 Марта, 2015 - 11:50:59
Post Id


Новичок


Покинул форум
Сообщений всего: 17
Дата рег-ции: Окт. 2014  


Помог: 0 раз(а)




Я PDO не знаю, он мне не нужен. А именно скрипт который написал я, он правильный?
 
 Top
DeepVarvar Супермодератор
Отправлено: 16 Марта, 2015 - 11:59:02
Post Id



Активный участник


Покинул форум
Сообщений всего: 10377
Дата рег-ции: Дек. 2008  
Откуда: Альфа Центавра


Помог: 353 раз(а)




ruslanaxti пишет:
он правильный?
Нет. Я написал словами как нужно поступать, не важно что там, пдо или майскули.
 
 Top
ruslanaxti
Отправлено: 16 Марта, 2015 - 12:37:52
Post Id


Новичок


Покинул форум
Сообщений всего: 17
Дата рег-ции: Окт. 2014  


Помог: 0 раз(а)




DeepVarvar пишет:
ruslanaxti пишет:
он правильный?
Нет. Я написал словами как нужно поступать, не важно что там, пдо или майскули.


Я в ООП не силен. Вы не мог ли бы явно мне указать, что после запросов их нужно проверять оператором if или сразу писать COMMIT
 
 Top
lastdays
Отправлено: 16 Марта, 2015 - 13:28:17
Post Id



Частый гость


Покинул форум
Сообщений всего: 221
Дата рег-ции: Март 2013  


Помог: 7 раз(а)




Откат нужен в случае, если if не прошел.
Короч, тут есть примеры: http://www[dot]slaed[dot]biz/mysqli[dot]rollback[dot]html
 
 Top
DelphinPRO
Отправлено: 16 Марта, 2015 - 20:46:54
Post Id



Активный участник


Покинул форум
Сообщений всего: 7187
Дата рег-ции: Февр. 2012  


Помог: 353 раз(а)




DeepVarvar пишет:
Чот я забыл насчет майскулИ, есть ли там как в ПДО PDO::ERRMODE_EXCEPTION

Если нет - надо добавить Улыбка

PHP:
скопировать код в буфер обмена
  1. class DbException extends Exception {}
  2.  
  3. mysqli_query(mysqlconnect(),"SET AUTOCOMMIT=0");
  4. mysqli_query(mysqlconnect(),'START TRANSACTION');
  5.  
  6. try {
  7.     $q1 = mysqli_query(mysqlconnect(), "UPDATE ..." );
  8.     if ($q1 === false) {
  9.         throw new DbException('Error #' . mysqli_errno(mysqlconnect()));
  10.     }
  11.    
  12.     $q2 = mysqli_query(mysqlconnect(), "INSERT ..." );
  13.     if ($q2 === false) {
  14.         throw new DbException('Error #' . mysqli_errno(mysqlconnect()));
  15.     }
  16.    
  17.     mysqli_query(mysqlconnect(),"COMMIT");
  18.    
  19. } catch(DbException $e) {
  20.  
  21.     mysqli_query(mysqlconnect(),"ROLLBACK");
  22.  
  23. }

(Отредактировано автором: 16 Марта, 2015 - 20:47:24)



-----
Чем больше узнаю, тем больше я не знаю.
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Вопросы новичков »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB