0 / 0 / 1
Регистрация: 04.03.2018
Сообщений: 8

SQL Server "В таблице, на которую имеются ссылки, отсутствуют первичные или потенциальные ключи"

04.03.2018, 21:44. Показов 16892. Ответов 3

Студворк — интернет-сервис помощи студентам
Проблемы с SQL Server

Делаю БД для некоторого бара

Создал сущность "Товар":
SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
USE LivlagsBar
GO
IF EXISTS (SELECT name FROM sys.objects
 WHERE name = 'Good' AND type_desc = 'USER_TABLE')
DROP TABLE Good
GO
CREATE TABLE Good
(Goods_code VARCHAR(10) NOT NULL PRIMARY KEY,
Goods_name VARCHAR(30) NOT NULL,
Good_Capacity FLOAT NOT NULL,
Quantity_available FLOAT NOT NULL,
Alcohol_content FLOAT,
Good_kind_code VARCHAR(10),
CONSTRAINT Good_kind_code_FK FOREIGN KEY (Good_kind_code)
REFERENCES Good_kind (Good_kind_code)
)
Цены на товары со временем меняються, поэтому есть сущность "Прайслист_товара":
SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
USE LivlagsBar
GO
IF EXISTS (SELECT name FROM sys.objects
 WHERE name = 'Good_priselist' AND type_desc = 'USER_TABLE')
DROP TABLE Good_priselist
GO
CREATE TABLE Good_priselist
(Good_priselist_code VARCHAR(10) NOT NULL,
Goods_code VARCHAR(10) NOT NULL,
PRIMARY KEY (Good_priselist_code, Goods_code),
Good_priselist_date datetime,
Good_prise money NOT NULL,
CONSTRAINT Goods_code_FK_priselist FOREIGN KEY (Goods_code)
REFERENCES Good (Goods_code)
)
А вот создание сущности самого факта продажи видает ошибку:
SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
USE LivlagsBar
GO
IF EXISTS (SELECT name FROM sys.objects
 WHERE name = 'Good_sale' AND type_desc = 'USER_TABLE')
DROP TABLE Good_sale
GO
CREATE TABLE Good_sale
(Check_code VARCHAR(10) NOT NULL,
Goods_code VARCHAR(10) NOT NULL,
PRIMARY KEY (Check_code, Goods_code),
Purchase_datetime datetime,
Sold_goods_quantity FLOAT,
Good_priselist_code VARCHAR(10),
 
CONSTRAINT Goods_code_FK_goodsale FOREIGN KEY (Goods_code, Good_priselist_code)
REFERENCES Good_priselist (Goods_code, Good_priselist_code),
CONSTRAINT Good_priselist_code_FK_goodsale FOREIGN KEY (Good_priselist_code)
REFERENCES Good_priselist (Good_priselist_code),
)
Текст ошибки:

Msg 1776, Level 16, State 0, Line 7
В таблице "Good_priselist", на которую имеются ссылки, отсутствуют первичные или потенциальные ключи, соответствующие списку ссылающихся столбцов во внешнем ключе "Goods_code_FK_goodsale".
Msg 1750, Level 16, State 1, Line 7
Не удалось создать ограничение или индекс. См. описание предыдущих ошибок.



Первый вопрос: Можно ли вообще, чтобы внешний ключ ссылался на внешний ключ другой таблицы?
Второй вопрос: Если да, тогда в чем проблема?

Добавлено через 18 минут
Возможно нельзя ссылаться на часть первичного ключа, то есть только на Goods_code или Good_priselist_code?
Тогда вопрос в том как это реализовать.
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
04.03.2018, 21:44
Ответы с готовыми решениями:

В таблице, на которую имеются ссылки, отсутствуют первичные или потенциальные ключи, соответствующие списку
Здравствуйте! Только начинаю изучать БД, возникли проблемы при создании следующего запроса: CREATE TABLE logistics.dbo.Production ( ...

В таблице "raspis", на которую имеются ссылки, отсутствуют первичные или потенциальные ключи, соответствующие списку
Ошибка: В таблице "raspis", на которую имеются ссылки, отсутствуют первичные или потенциальные ключи, соответствующие списку ссылающихся...

Определить потенциальные первичные ключи в таблицах

3
3614 / 2135 / 756
Регистрация: 02.06.2013
Сообщений: 5,169
04.03.2018, 22:22
Лучший ответ Сообщение было отмечено LiVlad как решение

Решение

Цитата Сообщение от LiVlad Посмотреть сообщение
Можно ли вообще, чтобы внешний ключ ссылался на внешний ключ другой таблицы?
FK должен ссылаться на столбцы родительской таблицы по которым построен primary key или unique constraint или unique index.
И не важно входят ли эти столбцы в родительской таблице в другой FK.
Цитата Сообщение от LiVlad Посмотреть сообщение
Возможно нельзя ссылаться на часть первичного ключа
Именно.
Цитата Сообщение от LiVlad Посмотреть сообщение
Тогда вопрос в том как это реализовать.
В вашем конкретном случае нужно Goods_sale писать цену, а не ссылку на прайс-лист. Иначе бармен, который вдруг захочет сделать скидку своему другу и т.п., вас прибьет.
2
0 / 0 / 1
Регистрация: 04.03.2018
Сообщений: 8
04.03.2018, 22:37  [ТС]
Тогда как?

Удалять вообще Priselist. И просто добавить 2 поля Good_prise в сущность Good, и в сущность Good_sale?
И уже в приложении просто предлагать ввести цену с Good в Good_sale с возможностью редактирования.

База так гараздо упрощается.
0
3614 / 2135 / 756
Регистрация: 02.06.2013
Сообщений: 5,169
05.03.2018, 09:19
LiVlad, да, примерно так. Если потребуется история цен, ее потом можно будет легко организовать.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
05.03.2018, 09:19
Помогаю со студенческими работами здесь

Сформировать SQL-запросы на создание таблиц, определив первичные ключи
Здравствуйте. Не получается сделать задание: База данных содержит две таблицы: «Начисления» и «Выплата» , связанные по ключу...

Для данных таблиц укажите первичные ключи, внешние ключи, постройте связи между таблицами

Составные потенциальные ключи
Добрый вечер! Подскажите, что я не так делаю Мне нужно создать таблицу, в которой 3 потенциальных ключа. (естественно, один из них...

Как деактивировать или отключить несколько строк в таблице SQL Server?
Можно ли деактивировать или отключить несколько строк в таблице SQL Server, чтобы запросы в приложении пропускали эти строки? Чтобы потом в...

Как выставить потенциальные ключи в таблицах?
Нужно связать две таблицы связью (Показана красной линией)


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Опции темы

Новые блоги и статьи
Отчёт о затраченных материалах за определенный период с макетом печатной формы
Maks 21.04.2026
Отчёт из решения ниже размещён в конфигурации КА2. Задача: разработка отчёта по затраченным материалам за определённый период, с возможностью вывода печатной формы отчёта с шапкой и подвалом. В. . .
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "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
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru