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

Форум MySQL

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

 

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

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

тема: INSERT или UPDATE?
 
 автор: Хулиган   (29.06.2013 в 23:51)   письмо автору
 
 

Здравствуйте!
Возникла необходимость определить,что именно выполнил запрос
INSERT INTO `main` ....... ON DUPLICATE KEY UPDATE.....

INSERT или UPDATE?
Можно ли узнать это?

  Ответить  
 
 автор: Sfinks   (30.06.2013 в 12:42)   письмо автору
 
   для: Хулиган   (29.06.2013 в 23:51)
 

При апдейте affected_rows всегда в два раза больше чем при инсерте.
Т.е. если вы вставляли 2 строки, то при affected_rows:
=2 - было вставлено 2 строки
=3 - была вставлена 1 строка, 1 обновлена
=4 - обе были обновлены.

  Ответить  
 
 автор: Хулиган   (30.06.2013 в 18:28)   письмо автору
 
   для: Sfinks   (30.06.2013 в 12:42)
 

ага, есть такое, правда непонятно, при апдейте одной строки выдает 3, а если строки не было, выдает 1. Почему 1 при вставке - понятно, а почему 3 при апдейте - непонятно, запрос был по уникальному полю, так что две записи никак не могли быть задействованы.

  Ответить  
 
 автор: Valick   (30.06.2013 в 14:44)   письмо автору
 
   для: Хулиган   (29.06.2013 в 23:51)
 

mysql_insert_id ?

  Ответить  
 
 автор: Хулиган   (30.06.2013 в 18:24)   письмо автору
 
   для: Valick   (30.06.2013 в 14:44)
 

Если я не ошибаюсь, mysql_insert_id работает, если задествован auto increment, а у меня его нет

  Ответить  
 
 автор: Valick   (30.06.2013 в 21:57)   письмо автору
 
   для: Хулиган   (30.06.2013 в 18:24)
 

Если не ошибаюсь, то Пушкин забыл это написать в первом посте ;)

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

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