|
2 / 2 / 0
Регистрация: 19.12.2019
Сообщений: 39
|
||||||
Обновить запись в MySQL, а если ее нет - добавить22.12.2019, 12:31. Показов 13312. Ответов 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
|
|
|
3900 / 3238 / 1353
Регистрация: 01.08.2012
Сообщений: 10,914
|
||||||
| 24.12.2019, 23:52 | ||||||
|
Directorosea, пример из гугла:
0
|
||||||
|
2 / 2 / 0
Регистрация: 19.12.2019
Сообщений: 39
|
|
| 25.12.2019, 13:28 [ТС] | |
|
Jodah, Это да.. Это из гугла. Это я уже выучил наизусть. Не работает это.
0
|
|
|
3900 / 3238 / 1353
Регистрация: 01.08.2012
Сообщений: 10,914
|
|
| 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
|
||||||
|
3900 / 3238 / 1353
Регистрация: 01.08.2012
Сообщений: 10,914
|
|
| 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
|
|
|
1315 / 1007 / 232
Регистрация: 01.10.2018
Сообщений: 3,910
|
||
| 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
|
|
|
1315 / 1007 / 232
Регистрация: 01.10.2018
Сообщений: 3,910
|
|
| 27.12.2019, 12:21 | |
|
Directorosea, PRIMARY KEY - по определению UNIQUE
![]() Добавлено через 2 минуты В документации по "ON DUPLICATE KEY UPDATE" об этом всем должно быть написано. К чему лишние разговоры?
0
|
|
| 27.12.2019, 12:21 | |
|
Помогаю со студенческими работами здесь
11
Как проверить запись на существование и добавить ее в базу данных если ее там нет или отредактировать если она там есть? Если строки с такой записью нет - создать, если есть - обновить Если есть поле - обновить, если нет - создать
Добавить если не существует иначе обновить redbeanphp Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
|
Запрет удаления строк ТЧ документа при определенном условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
|
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут
Суть:
- Группа наркоманов из 10 человек.
- Только один инфицирован ВИЧ.
- Колются одной иглой.
- Колются раз в день.
- Колются последовательно через. . .
|
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
|
|
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
|
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . .
а удачный момент так и не приходит.
|
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица.
Задача: зафиксировать три левых колонки в отчете.
Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка)
/ / . . .
|
Настройки VS Code
Loafer 13.04.2026
{
"cmake. configureOnOpen": false,
"diffEditor. ignoreTrimWhitespace": true,
"editor. guides. bracketPairs": "active",
"extensions. ignoreRecommendations": true,
. . .
|