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

Форум MySQL

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

 

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

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

тема: Обновить, если сущесвует, нет - вставить
 
 автор: NightSoldier   (21.09.2009 в 17:15)   письмо автору
 
 

Столкнулся с такой проблемой!
Если запись существует, то обновить, нет - вставить.

Из 3-х запросов я могу сделать=)))! Но можно ли всё в 1 способе сделать, вот мой пример:

$sql_r=mysql_fetch_array(mysql_query("SELECT id FROM online WHERE id='$_SESSION[online]'"));
  if ($sql_r)
      mysql_query("UPDATE online SET lastvis='$time', user_id=$sql_p WHERE id='$_SESSION[online]' ");
  else
      mysql_query("INSERT INTO `online` VALUES (
'$_SESSION[online]', '$time', $sql_p 
);");


Поясню в данном случае SELECT - проверяет, если запись, если нет - создать, да - обновить.
В данном случае обновить нужно только одну ячейку (или как там её) - "lastvis"
Плиз можно это всё в 1 запрос сократить???
Кстати PRIMARY у мну нету в таблице!

  Ответить  
 
 автор: Волки   (21.09.2009 в 17:26)   письмо автору
 
   для: NightSoldier   (21.09.2009 в 17:15)
 

примерно так:
http://stackoverflow.com/questions/1218905/how-do-i-update-if-exists-insert-if-not-aka-upsert-or-merge-in-mysql

  Ответить  
 
 автор: psychomc   (21.09.2009 в 18:14)   письмо автору
 
   для: Волки   (21.09.2009 в 17:26)
 

не вникал, но может REPLACE http://www.mysql.ru/docs/man/REPLACE.html

  Ответить  
 
 автор: Trianon   (21.09.2009 в 19:52)   письмо автору
 
   для: NightSoldier   (21.09.2009 в 17:15)
 

>Кстати PRIMARY у мну нету в таблице!
Был бы - можно было бы.

  Ответить  
 
 автор: NightSoldier   (22.09.2009 в 15:14)   письмо автору
 
   для: Trianon   (21.09.2009 в 19:52)
 

вот поэтому и добавил, знаю что с помощью него можно, но увы-(

  Ответить  
 
 автор: Trianon   (22.09.2009 в 15:18)   письмо автору
 
   для: NightSoldier   (22.09.2009 в 15:14)
 

А что препятствует добавлению индекса первичного ключа?
Кстати достаточно уникального индекса, необязательно именно первичный.
Это я к тому, что если первичный ключ уже есть - это не препятствие.

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

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