Форум программистов, компьютерный форум, киберфорум
Microsoft SQL Server
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.93/88: Рейтинг темы: голосов - 88, средняя оценка - 4.93
0 / 0 / 1
Регистрация: 04.03.2018
Сообщений: 8

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

04.03.2018, 21:44. Показов 16837. Ответов 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
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru