Гость
Целевая тема:
Создать новую тему:
Автор:
Форумы / MySQL [игнор отключен] [закрыт для гостей] / Вставить вместо NULL, а если NULL нету, то добавить строку / 17 сообщений из 17, страница 1 из 1
13.01.2017, 20:07
    #39384500
sergiksergik
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Вставить вместо NULL, а если NULL нету, то добавить строку
Подскажите как реализовать 1 запросом

т.е. берем одно значение из одной таблицы и ложим в другую таблицу, но ложим в ячейку содержащее NULL, если NULL отсутствует, то добавляем новую строку

Что то у меня с данным запросом не хочет работать
Спасибо

Код: plsql
1.
2.
3.
4.
5.
IF ((SELECT COUNT(*) stolb FROM tabl WHERE stolb IS NULL) == 0) THEN
	INSERT INTO tabl (stolb) VALUES ('znach');
ELSE
	UPDATE tabl SET stolb='znach' WHERE stolb IS NULL LIMIT 1;
END IF;
...
Рейтинг: 0 / 0
13.01.2017, 21:08
    #39384551
Akina
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Вставить вместо NULL, а если NULL нету, то добавить строку
sergiksergikу меня с данным запросом не хочет работать
Это - НЕ запрос с точки зрения MySQL.

sergiksergikберем одно значение из одной таблицы и ложим в другую таблицу, но ложим в ячейку содержащее NULL, если NULL отсутствует, то добавляем новую строкуНет такого. Есть только два вида совмещённых запросов:
явнодуальный - INSERT ON DUPLICATE KEY UPDATE
неявнодуальный - REPLACE
...
Рейтинг: 0 / 0
13.01.2017, 21:11
    #39384555
sergiksergik
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Вставить вместо NULL, а если NULL нету, то добавить строку
Спасибо
Можно тогда написать запрос на мою проблему?
а то опять составлю не запрос
...
Рейтинг: 0 / 0
13.01.2017, 21:21
    #39384562
Akina
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Вставить вместо NULL, а если NULL нету, то добавить строку
Нет. Можно - два запроса. Или - хранимую процедуру. Последнее имхо оптимум.
...
Рейтинг: 0 / 0
13.01.2017, 21:35
    #39384569
sergiksergik
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Вставить вместо NULL, а если NULL нету, то добавить строку
Можешь помочь написать для моего вариант?
...
Рейтинг: 0 / 0
13.01.2017, 22:20
    #39384580
Akina
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Вставить вместо NULL, а если NULL нету, то добавить строку
sergiksergikМожешь помочь
Лехко... http://dev.mysql.com/doc/refman/5.7/en/create-procedure.html
А всё остальное у тебя уже написано.
...
Рейтинг: 0 / 0
14.01.2017, 11:58
    #39384669
sergiksergik
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Вставить вместо NULL, а если NULL нету, то добавить строку
Кто может написать запрос?
Просьба не отсылать на учебники и давать советы.
Форум предназначен для помощи. Помогите, напишите готовый запрос.
...
Рейтинг: 0 / 0
14.01.2017, 22:40
    #39384845
Akina
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Вставить вместо NULL, а если NULL нету, то добавить строку
sergiksergikФорум предназначен для помощи.Вот именно - помощи... вот это почитайте...
...
Рейтинг: 0 / 0
15.01.2017, 11:32
    #39384939
sergiksergik
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Вставить вместо NULL, а если NULL нету, то добавить строку
я не студент
мне не нужно писать задания
мне нужен всего лишь запрос.
Не можете помочь? Пройдите мимо.
Может имеются люди, которые не умничают, а помогают, таким буду рад.

Повторю.
Напишите кто-нибудь запрос.
Я привел как делаю и что мне надо. Далее я не знаю как делать.
...
Рейтинг: 0 / 0
15.01.2017, 11:44
    #39384942
вадя
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Вставить вместо NULL, а если NULL нету, то добавить строку
sergiksergik,
не стоит обижаться , тебе дали полный ответ.
...
Рейтинг: 0 / 0
15.01.2017, 11:50
    #39384947
sergiksergik
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Вставить вместо NULL, а если NULL нету, то добавить строку
Я не обижаюсь
Я попросил просто написать запрос

Можно было просто написать эти пару строк, нет же, полезли по правилам, смотреть дл чего форум, тратить время свое.
За это время написали бы, либо проигнорировали.

Написал так
Код: plsql
1.
2.
3.
SET @A = (SELECT id FROM tabl WHERE stolb IS NULL LIMIT 1);
INSERT INTO tabl (id,stolb) VALUES (@A,znach)
ON DUPLICATE KEY UPDATE stolb = VALUES(stolb);
...
Рейтинг: 0 / 0
15.01.2017, 11:54
    #39384950
вадя
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Вставить вместо NULL, а если NULL нету, то добавить строку
sergiksergik,
смотри into
...
Рейтинг: 0 / 0
15.01.2017, 12:03
    #39384955
sergiksergik
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Вставить вместо NULL, а если NULL нету, то добавить строку
Да работает вроде.
...
Рейтинг: 0 / 0
15.01.2017, 20:05
    #39385094
Hett
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Вставить вместо NULL, а если NULL нету, то добавить строку
Работать то работает, но это, извиняюсь, говнокод. Сам через джва года забудешь в чем тут смысл и будешь долго голову ломать, не говоря уж о том случае если кому то вместо тебя это переделывать придется.
В чем проблема сделать селект (проверку) на клиенте?
...
Рейтинг: 0 / 0
15.01.2017, 20:37
    #39385109
sergiksergik
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Вставить вместо NULL, а если NULL нету, то добавить строку
В том, что я не знаю.
Я разбираться начал 2 недели назад.
Что сделал то сделал. Думал тут помощи найду, так тут почти все библиотекари
Только ссылки дают.

Так что, что есть, то есть.
Может через год новый состряпаю
...
Рейтинг: 0 / 0
15.01.2017, 21:32
    #39385122
Hett
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Вставить вместо NULL, а если NULL нету, то добавить строку
А запросы кто (точнее что) на сервер отправляет? Почему там эту логику не реализовать?
...
Рейтинг: 0 / 0
15.01.2017, 22:02
    #39385124
sergiksergik
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Вставить вместо NULL, а если NULL нету, то добавить строку
Ребята, не грузите плиз.
Дайте готовое решение и буду примного благодарен
...
Рейтинг: 0 / 0
Форумы / MySQL [игнор отключен] [закрыт для гостей] / Вставить вместо NULL, а если NULL нету, то добавить строку / 17 сообщений из 17, страница 1 из 1
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]