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

Проблема создания FOREIGN KEY

10.05.2022, 14:20. Показов 1231. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем привет! Не могу понять - в PostgeSQL возможно создать FOREIGN KEY только на уникальную колонку?!

Например, мне нужна таблица, в которой есть колонка `id`, которая не должна быть уникальной (unique), и колонка `parent_id`, которая может содержать ссылку на `id`. Таким образом я не могу указать в `parent_id` несуществующего `id`. Пример такой рабочей таблицы в MySQL:
SQL
1
2
3
4
5
6
7
8
9
10
CREATE TABLE `my_table` (
  `seq` INT NOT NULL,
  `node` INT NOT NULL,
  `parent_node` INT DEFAULT NULL,
  `data` VARCHAR(45) NOT NULL,
  PRIMARY KEY (`seq`),
  KEY `ix_node` (`node`),
  KEY `ix_parent_node` (`parent_node`),
  CONSTRAINT `fk_to_parent` FOREIGN KEY (`parent_node`) REFERENCES `my_table` (`node`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci
Название: pic.png
Просмотров: 105

Размер: 17.7 Кб

Как такую же таблицу реализовать в PostgreSQL? Я попробовал сделать так:
SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
CREATE TABLE IF NOT EXISTS public.my_table
(
    seq SERIAL,
    id INTEGER NOT NULL,
    parent_id INTEGER,
    DATA json,
    CONSTRAINT pk_my_table PRIMARY KEY (seq),
    CONSTRAINT fk_my_table_to_parent_id FOREIGN KEY (parent_id)
        REFERENCES public.my_table (seq) MATCH SIMPLE
        ON UPDATE NO ACTION
        ON DELETE NO ACTION
        NOT VALID
)
Ошибка:
Code
1
2
ERROR: there is no unique constraint matching given keys for referenced table "my_table"
SQL state: 42830
Похоже, что проблема в том, что колонка `id` не уникальная (unique). Но мне и не нужна уникальность в `id`! Я пробовал индексировать колонку `id` (CREATE INDEX), но проблему это не решило. Как выйти из ситуации?
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
10.05.2022, 14:20
Ответы с готовыми решениями:

PRIMARY/foreign KEY
Добрый день, Тoлько начал знакомство с PostgresSQL сейчас перевожу табл с MySQL в PostgresSQL есть такая табл CREATE TABLE `users` ( ...

SQLite - оптимальный размер транзакции, стоит ли использовать FOREIGN KEY, связь PRIMARY KEY и INDEX
1. Оптимальный размер транзакции 1.1. Есть ли какое-то ограничение на размер или содержание одной транзакции? 1.2. Может ли размер...

И снова ключи: PRIMARY KEY, FOREIGN KEY
Подскажите в чём тут ошибка? Не хочет создавать вторую таблицу. Глаза уже сломал... create table Contact_Date ( city varchar...

5
0 / 0 / 0
Регистрация: 25.04.2020
Сообщений: 136
10.05.2022, 14:26  [ТС]
Название: pic.png
Просмотров: 93

Размер: 20.2 Кб
0
0 / 0 / 0
Регистрация: 25.04.2020
Сообщений: 136
15.05.2022, 12:58  [ТС]
Кто-нибудь знает?
0
0 / 0 / 0
Регистрация: 25.04.2020
Сообщений: 136
24.05.2022, 23:10  [ТС]
Code
1
Внешний ключ должен ссылаться на столбцы, образующие первичный ключ или ограничение уникальности.
(postgrespro.ru/docs/postgresql/14/ddl-constraints)
0
1267 / 980 / 385
Регистрация: 02.09.2012
Сообщений: 3,027
26.05.2022, 00:41
Ну все правильно у вас в CREATE TABLE. Вероятно вы где-то какие-то ошибки допускаете при вводе запросов. Например не надо забывать точку с запятой при вводе запросов через psql.
0
0 / 0 / 0
Регистрация: 25.04.2020
Сообщений: 136
31.05.2022, 22:16  [ТС]
Цитата Сообщение от grgdvo Посмотреть сообщение
Вероятно вы где-то какие-то ошибки допускаете при вводе запросов.
Проблема была в том, что внешний ключ можно указать только на уникальное значение (Primary key или Unique), а у меня столбец 'node' не может быть уникальным.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
31.05.2022, 22:16
Помогаю со студенческими работами здесь

Зачем нужны primary key и foreign key?
Пожалуйста, объясните самым простым языком зачем эти ключи нужны? Какова их функция? Как они работают? В чём приемущество?

PRIMARY KEY, FOREIGN KEY
Добрый день. Только начал изучать MySQL, пробую написать скрипт создании БД. DROP TABLE IF EXISTS country; -- страны CREATE TABLE...

Как одной строкой запроса добавить один и тот же сгенерированный UUID в поле Key таблицы1 и в поле Foreign Key таблицы2 ?
У меня получается добавить одним запросом один и тот же UUID в две таблицы. Как одной строкой запроса добавить один и тот же...

FOREIGN KEY
Здравствуйте, возникла проблема: не получается задать длину ключа при создании внешнего ключа. Есть две таблицы : t1, t2. В t1 имеется...

Foreign KEY
Здравствуйте форумчане. Помогите с проблемой. Впервые настраиваю связи в БД. Ситуация: есть 4 справочника (приведу сокращенные названия) ...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Модель ЗдрввоСохранения 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