Форум программистов, компьютерный форум, киберфорум
PostgreSQL
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/4: Рейтинг темы: голосов - 4, средняя оценка - 4.75
0 / 0 / 0
Регистрация: 13.12.2019
Сообщений: 6

Insert values

20.02.2020, 16:08. Показов 801. Ответов 1

Студворк — интернет-сервис помощи студентам
Заранее признателен за помощь всем откликнувшимся. Есть три таблицы:
1.Ресторан
2.Категория
3. Подкатегория
Происходит миграция бд. В подкатегории есть category_id - указывающая в какой категории лежит данная подкатегория. Соответственно в категории есть - restaurant_id который указывает в каком ресторане лежит данная категория. Все три таблицы не связаны между собой внешним ключом(не ко мне вопросы). Нужно в подкатегории заменить столбец category_id на restorant_id, таким образом чтобы все подкатегории были связанны с ресторанами в которых они раньше находились. Т.е. иначе формулируя если раньше подкатегории были связанны с категориями и за счет этого они находились в нужных местах. То теперь из иерархии исчезают категории и подкатегориям нужно подсунуть restaurant_id в которых они лежат.

Таблица ресторан
SQL
1
2
3
4
5
6
7
CREATE TABLE public.restaurant
(
    id BIGINT NOT NULL DEFAULT NEXTVAL('restaurant_id_seq'::regclass),
    active BOOLEAN DEFAULT TRUE,
    address CHARACTER VARYING(255) COLLATE pg_catalog."default" NOT NULL,
    avgprice INTEGER NOT NULL,
)
Таблица категории

SQL
1
2
3
4
5
6
7
8
CREATE TABLE public.category
(
    id BIGINT NOT NULL DEFAULT NEXTVAL('category_id_seq'::regclass),
    active BOOLEAN DEFAULT TRUE,
    name CHARACTER VARYING(255) COLLATE pg_catalog."default" NOT NULL,
    restaurant_id BIGINT,
    CONSTRAINT category_pkey PRIMARY KEY (id),
)
Таблица подкатегории
SQL
1
2
3
4
5
6
7
8
CREATE TABLE public.subcategory
(
    id BIGINT NOT NULL DEFAULT NEXTVAL('subcategory_id_seq'::regclass),
    active BOOLEAN DEFAULT TRUE,
    name CHARACTER VARYING(255) COLLATE pg_catalog."default" NOT NULL,
    category_id BIGINT,
    CONSTRAINT subcategory_pkey PRIMARY KEY (id)
)
Ну и скрины как это выглядит
Категория:

Подкатегория:

Ресторан
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
20.02.2020, 16:08
Ответы с готовыми решениями:

INSERT, подзапрос и VALUES
Подскажите пожалуйста, вот чтобы добавить данные из таблиц работает такой запрос INSERT INTO metric_values(mv_db_id, mv_cat_id) ...

INSERT, вложенный в INSERT
Господа формучане, доброго времени суток. У меня мало опыта работы с реляционными БД, посему прошу помощи у вас. У меня такая...

Insert Values
insert into (grouping) values ('group3='100''); - это упрощённый вариант того что мне нужно. подскажите пожалуйста, как в тестовое...

1
1267 / 980 / 385
Регистрация: 02.09.2012
Сообщений: 3,027
21.02.2020, 06:37
Например,
Старт транзакции
Действие 1. Добавить в таблицу подкатегория новое поле restaurant_id with null.
Действие 2. Написать запрос, который делает UPDATE subcategory FROM category, чтобы проставить правильный restaurant_id из category.
Действие 3. При необходимости убрать NULL-ограничение у нового поля restaurant_id.
Дейсвтие 4. Прогнать тест (SELECT), который проверит правильность переноса.
Коммит транзакции.
Если все успешно, удалить поле category_id.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
21.02.2020, 06:37
Помогаю со студенческими работами здесь

INSERT INTO VALUES SELECT
добрый вечер) помогите пожалуйста сделать запрос.... Нужно с одной таблицы добавить данные в другую..и приэтом еще ввести некотрые...

Запрос на добавление INSERT INTO .VALUES
Здравствуйте, Пишу такой запрос insert into shop (id, name, color) Values (123,'roza', (select color from tab where id=123)); ...

insert into table values (select....
Здравствуйте, скажите, как заставить работать следующий запрос: insert into tg3.dbo.tg3hour values (getdate(),select avg() from ..) ...

Получить и проверить значение из values при insert
Я не знаю можно ли сделать такое. Но мне надо получить из values и проверить на совпадение. Общий смысл в том, чтобы в процессе...

Insert: column name or number of supplied values does not match table definition
Добрый вечер! На форме имеется 11 полей ввода: 7 string(2 comboBox & 5 textBox), 3 int, 1 date. Столкнулся с проблемой при попытки...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20%
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
Использование значений реквизитов справочника в документе, с определенными условиями и правами
Maks 07.04.2026
1. Контроль срока действия договора Алгоритм из решения ниже реализован на примере нетипового документа "ЗаявкаНаРаботу", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если. . .
Доступность команды формы по условию
Maks 07.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: сделать доступной кнопку (команда формы "ЗавершитьСписание") при. . .
Уведомление о неверно выбранном значении справочника
Maks 06.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "НарядПутевка", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если в документе выбран неверный склад. . .
Установка Qt Creator для C и C++: ставим среду, CMake и MinGW без фреймворка Qt
8Observer8 05.04.2026
Среду разработки Qt Creator можно установить без фреймворка Qt. Есть отдельный репозиторий для этой среды: https:/ / github. com/ qt-creator/ qt-creator, где можно скачать установщик, на вкладке Releases:. . .
AkelPad-скрипты, структуры, и немного лирики..
testuser2 05.04.2026
Такая программа, как AkelPad существует уже давно, и также давно существуют скрипты под нее. Тем не менее, прога живет, периодически что-то не спеша дополняется, улучшается. Что меня в первую очередь. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru