|
2 / 2 / 0
Регистрация: 19.12.2019
Сообщений: 39
|
||||||
Обновить запись в MySQL, а если ее нет - добавить22.12.2019, 12:31. Показов 13166. Ответов 10
Метки нет (Все метки)
Всем привет! С наступающим новым годом! Парни подскажите пожалуйста - вот такая таблица MYTABLE
id ----------- dt ---------- tm --------ip --------------cmd 100200___12.12.19___ 22:41 ___192.168.0.1___N/A
Вопрос - как сделать в данном конкретном случае так, чтобы строка не только обновлялась с такимм id, но и добавлялась новая, если такого id нету. Понимаю, что можно сделать через select там типо поиск и потом if и insert into , но чувствую не могли создатели mysql не предусмотреть такой возможности Сильно не пинайте если что не так написал )
0
|
||||||
| 22.12.2019, 12:31 | |
|
Ответы с готовыми решениями:
10
Запрос: если записи нет - добавить, если есть - обновить
триггеры на проверку если запись есть то пропустить если нет то добавить... |
|
2 / 2 / 0
Регистрация: 19.12.2019
Сообщений: 39
|
|
| 23.12.2019, 13:37 [ТС] | |
|
Может тогда подскажете, как сделать через поиск?
0
|
|
|
3899 / 3237 / 1353
Регистрация: 01.08.2012
Сообщений: 10,909
|
||||||
| 24.12.2019, 23:52 | ||||||
|
Directorosea, пример из гугла:
0
|
||||||
|
2 / 2 / 0
Регистрация: 19.12.2019
Сообщений: 39
|
|
| 25.12.2019, 13:28 [ТС] | |
|
Jodah, Это да.. Это из гугла. Это я уже выучил наизусть. Не работает это.
0
|
|
|
3899 / 3237 / 1353
Регистрация: 01.08.2012
Сообщений: 10,909
|
|
| 25.12.2019, 13:56 | |
|
0
|
|
|
2 / 2 / 0
Регистрация: 19.12.2019
Сообщений: 39
|
||||||
| 25.12.2019, 15:46 [ТС] | ||||||
|
Jodah, Привет! Ну а что расписывать... если только предметно:
MYTABLE id ----------- dt ---------- tm --------ip --------------cmd 100200___12.12.19___ 22:41 ___192.168.0.1___N/A Все переменные получаю из $_POST
Остальное типо INSERT INTO и UPDATE все освоил и разобрался - работает. А вот on duplicate key update не хочет... а так нужно ![]() Добавлено через 53 секунды UPDATE..........WHERE тоже работает.. Добавлено через 15 минут Пробовал поиграться с кавычками по всякому ... думал может синтаксис что.. максимум что добился - появляются новые строки, но никак не заменяются старые
0
|
||||||
|
3899 / 3237 / 1353
Регистрация: 01.08.2012
Сообщений: 10,909
|
|
| 25.12.2019, 17:12 | |
Сообщение было отмечено Directorosea как решение
Решение
1
|
|
|
2 / 2 / 0
Регистрация: 19.12.2019
Сообщений: 39
|
|
| 25.12.2019, 20:03 [ТС] | |
|
ДА? а я вроде как понял мануалы, что там указывается то значение, по которому надо найти строку и в ней замену )
Добавлено через 4 минуты Попробовал... нет. Все я правильно делал. Просто не работает. Добавлено через 5 минут Вообще запутался: Повторюсь : MYTABLE id ----------- dt ---------- tm --------ip --------------cmd 100200___12.12.19___ 22:41 ___192.168.0.1___N/A 218392___12.12.19___12:33____107.212.32. 12.__Help Входные данные: $id $dt $tm $ip $cmd Нужно: Найти строку где есть указанный во вход. данных id и обновить в этой строке значения dt tm ip cmd Если нет строки с таким id, то ее соответственно нужно создать. Я окончательно запутался, Можете скинуть конкретный применительно к этой ситуации запрос? каков он? Добавлено через 17 секунд Jodah, Добавлено через 12 минут Уфф.. все заработало... я неправильно представлял принцип работы этой команды... честно говоря и сейчас не очень мне их задумка понравилась.... должно быть другое решение. Вообщем этому полю id еще нужно было поставить опцию что оно первичное.
0
|
|
|
1308 / 1000 / 232
Регистрация: 01.10.2018
Сообщений: 3,894
|
||
| 26.12.2019, 12:00 | ||
![]() Добавлено через 10 минут Если идентификатор все же может меняться, посмотрите еще REPLACE. Там синтаксис компактнее (без дублирования отдельных полей и их значений).
0
|
||
|
2 / 2 / 0
Регистрация: 19.12.2019
Сообщений: 39
|
|
| 26.12.2019, 15:21 [ТС] | |
|
estic, Привет! Да действительно - экспериментально выяснилось, что все же UNIQUE нужно!
Добавлено через 54 секунды Что поделать PHP и MySQL пятый день лишь изучаю. Хотя признаться думал что все куда сложнее.Добавлено через 3 минуты А вообще удобная эта штука mySQL на стороне серверной части. Все четко работает, нужно лишь раз правильно все настроить )
0
|
|
|
1308 / 1000 / 232
Регистрация: 01.10.2018
Сообщений: 3,894
|
|
| 27.12.2019, 12:21 | |
|
Directorosea, PRIMARY KEY - по определению UNIQUE
![]() Добавлено через 2 минуты В документации по "ON DUPLICATE KEY UPDATE" об этом всем должно быть написано. К чему лишние разговоры?
0
|
|
| 27.12.2019, 12:21 | |
|
Помогаю со студенческими работами здесь
11
Как проверить запись на существование и добавить ее в базу данных если ее там нет или отредактировать если она там есть? Если строки с такой записью нет - создать, если есть - обновить Если есть поле - обновить, если нет - создать
Добавить если не существует иначе обновить redbeanphp Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога
Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
|
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование
. \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json>
Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом.
# Check if. . .
|
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так:
https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347
Основана на STM32F303RBT6.
На борту пять. . .
|
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
|
|
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу,
и светлой Луне.
В мире
покоя нет
и люди
не могут жить в тишине.
А жить им немного лет.
|
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила»
«Время-Деньги»
«Деньги -Пуля»
|
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога
Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
|
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога
Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
|