Форум программистов, компьютерный форум, киберфорум
PHP: базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/63: Рейтинг темы: голосов - 63, средняя оценка - 4.75
Веб-мастер
 Аватар для Maksimchikfull
89 / 89 / 19
Регистрация: 11.08.2011
Сообщений: 674

INSERT, SELECT, UPDATE, DELETE в одном запросе

15.02.2012, 14:01. Показов 12460. Ответов 10
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
На самом деле мне надо совместить INSERT и UPDATE.

Дело в том, когда совмещаю примерно таким образом:
PHP
1
2
3
mysql_query("
INSERT INTO `users` (`date`) VALUES ('". strtotime('now') ."')
UPDATE `regs` SET `date` = '1' WHERE `id` = '1'");
У меня не работает, и начинает жаловатся со слова UPDATE. Ошибка примерно такая:
You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'UPDATE `regs` SET `date` = '1' WHERE `id` = '1'' at line 1

Пытался ставить запятую перед UPDATE, и точку-запятой, и AND думая что после INSERT действие как-бы сказать, произойдет и будет выполнять следующее.

Пытался искать тут и гуглил, не докапывался.

Добавлено через 7 минут
Прочитал что-то, написали что mysql_query не поддерживает несколько комманд. Правда?

Добавлено через 37 секунд
Если да, то возможно сделать чтобы было как мне надо? Или всеже придется 2 раза вызывать mysql_query?
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
15.02.2012, 14:01
Ответы с готовыми решениями:

select-insert-update в одном запросе
мне нужен был запрос такого рода - проверить есть ли такая запись, если есть то к той записи просто счетчик +1, если нет то занести запись...

Использование операторов SELECT, DELETE и UPDATE в одном запросе в PDO
возможно ли в одном запросе к базе использовать операторы SELECT, DELETE и UPDATE если можно то как (в примере) Добавлено через 11...

Нужны универсальные функции INSERT, SELECT, UPDATE и DELETE!
Добрый день, уважаемые коллеги! Не могли бы вы помочь новичку?! В общем есть База Данных. В Денвере. (хотя БД не имеет значения) ...

10
4217 / 3059 / 583
Регистрация: 21.01.2011
Сообщений: 13,203
15.02.2012, 14:26
Почему 2 раза не вызвать?
0
65 / 65 / 6
Регистрация: 22.09.2010
Сообщений: 182
15.02.2012, 15:31
1) в чем проблема делать 2 запроса?
2) если надо делать апдейт только если не получился инсерт из-за дублирующихся ключей - есть ON DUPLICATE KEY http://dev.mysql.com/doc/refma... icate.html
0
Веб-мастер
 Аватар для Maksimchikfull
89 / 89 / 19
Регистрация: 11.08.2011
Сообщений: 674
15.02.2012, 16:25  [ТС]
Окей. Скажу так. У меня есть цикл, который составляет запросы(Текст). Он склеивается с переменной $query. А та переменная после цикла вставляется в mysql_query. И чтобы не вызывать по 200 раз функцию. Я думаю сделать за раз.
0
 Аватар для acupation
67 / 67 / 6
Регистрация: 26.03.2010
Сообщений: 546
15.02.2012, 16:42
PHP
1
2
3
$perem=strtotime($now);
mysql_query("INSERT INTO `users` (`date`) VALUES ('".$perem ."')");
mysql_query("UPDATE `regs` SET `date` = '".$perem."' WHERE `id` = '1'");
Добавлено через 1 минуту
Я просто не понимаю как у тебя сделано наверно)) Дай код, глянем.
0
4217 / 3059 / 583
Регистрация: 21.01.2011
Сообщений: 13,203
15.02.2012, 16:55
Цитата Сообщение от Maksimchikfull
А та переменная после цикла вставляется в mysql_query. И чтобы не вызывать по 200 раз функцию. Я думаю сделать за раз.
Ты хочешь сделать так, как тебе удобнее писать программу. А программист, работающий с БД должен еще думать о том, как удобнее и оптимальнее работать самой БД. А БД за один раз может выполнить только один запрос от одной сессии. Типа получила SQL-предложение, выполнила, возвратила результат и ждет следующего SQL
0
Веб-мастер
 Аватар для Maksimchikfull
89 / 89 / 19
Регистрация: 11.08.2011
Сообщений: 674
15.02.2012, 17:05  [ТС]
Подобно этому:
PHP
1
2
3
4
5
6
7
$row = mysql_fetch_array(/* QUERY */);
if($row['id'] != ""){
    do{
        mysql_query("UPDATE `users` SET `online` = '0' WHERE `id` = '$row[id]'");
    }
    while($row = mysql_fetch_array(/* QUERY */));
}
Теперь представим, что этот цикл выполнить код раз 1000. Что у меня и было, только около 400. У меня просто сервер повис, и пока я его не перезапущу, он не работает.

И выжидал, домой пришол, спустя несколько часов. Сервер досихпор висел.
0
65 / 65 / 6
Регистрация: 22.09.2010
Сообщений: 182
15.02.2012, 17:33
Это заблуждение что один запрос - лучше. Не всегда. В вашем случае лучше мне кажеться будет лучше (для БД) делать много запросов.
Если это занимает время больше, чем дано PHP на отработку скрипта - можно пойти другим путем. Каким? Тут надо больше подробностей. Например, как вы выбираете эти id?
1
Веб-мастер
 Аватар для Maksimchikfull
89 / 89 / 19
Регистрация: 11.08.2011
Сообщений: 674
15.02.2012, 18:25  [ТС]
Ясно. Мне этого достаточно. id выбираются по условию.
0
65 / 65 / 6
Регистрация: 22.09.2010
Сообщений: 182
15.02.2012, 19:24
Я имел ввиду что можно это вынести в какую-то таблицу очереди и обрабатывать ее по крону.
0
4217 / 3059 / 583
Регистрация: 21.01.2011
Сообщений: 13,203
16.02.2012, 09:36
SQL
1
UPDATE `users` SET `online` = '0' WHERE `id` = '$row[id]'
Куча таких запросов эквивалентна одному такому:
SQL
1
UPDATE `users` SET `online` = '0' WHERE `id` IN (val1, val2, ....)
Правда, если значений много, то можно натолкнуться на ограничения сервера (какое у MySQL не помню, у Oracle где-то около 1000).
В таком случае м.б. удобно (если это действие не разовое, а регулярное) записать эти значения в таблицу, а потом выполнить UPDATE одним запросом.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
16.02.2012, 09:36
Помогаю со студенческими работами здесь

Insert,update,delete
Добрый вечер. Есть такой вот класс <?php class GoodsClass { public function getGoodsList(){ $mysqli = new...

Множественный update, delete, insert
Здравствуйте, возник довольно теоретический вопрос. Есть 2 таблицы, данные из первой таблицы содержат поле которое указывает на действия, с...

SQL Access Можно ли в одном запросе объединить Insert,delete,update
Можно ли в одном запросе объединить Insert,delete,update? или делать каждой команде новый запрос?

Не работают команды Insert, Select, Update, Delete
oFgl71x1PX4 Тут все четко и понятно все компилируется ни каких ошибок, запускается, но как только я произвожу действия с базой нажимаю на...

Select, delete, update, insert. как писать?
Всем привет. Как дописать delete, update, insert. Поиск по форуму не дал результатов, а черз гугл не понимаю на чужих примерах. Если...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
11
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru