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

Внешний ключ

28.09.2013, 13:00. Показов 1387. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте.
Существует некоторая база данных по учету запасов товаров. Возникла проблема со связью таблиц...
При создании связи между таблицами Shipper и CommondityType получаю ошибку. Очевидно это из-за того, что получаем замкнутый круг. Очень не хочется придумывать всякие извращения и отключать ограничения внешнего ключа.
Может быть кто-нибудь сталкивался и знает как выкрутится в такой ситуации.
Миниатюры
Внешний ключ   Внешний ключ  
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
28.09.2013, 13:00
Ответы с готовыми решениями:

Пустой внешний ключ
Добрый вечер! Будьте добры, подскажите как кодом написать, чтобы внешний ключ мог быть пустой?? вроде как on update set null но у меня...

Не удается создать внешний ключ
ALTER TABLE Krossirovka ADD FOREIGN KEY (ObjectFrom_ID) REFERENCES Object (Object_ID) не выполняется. Пишет "The ALTER TABLE...

Внешний ключ ссылается на недопустимую таблицу
Всем привет! Пишу запросы и столкнулся с проблемой в одной из связей! Создаю связь между таблицами, а мне выдает ошибку! ...

2
 Аватар для Kruds
708 / 708 / 226
Регистрация: 04.03.2013
Сообщений: 1,384
28.09.2013, 17:37
Здравствуйте.
Что-то подсказывает мне что поле "Грузоотправитель" в таблице "Тип товара" лишнее.
Если закрыть на это глаза то структура вполне логичная: в поставку от такого то отправителя включен набор товаров каждый из которых имеет свой тип.

Добавлено через 10 минут
Но если условия таковы что между типом товара и отправителем однозначное соответствие, то можно ввести этот внешний ключ, предварительно разорвав связь поставщик-поставка. По товару в поставке можно будет вытащить отправителя.
0
0 / 0 / 0
Регистрация: 08.07.2013
Сообщений: 21
28.09.2013, 18:23  [ТС]
Дело в том, что для каждого товара необходимо указать рекомендуемого поставщика. Из этого условия такие связи.

Добавлено через 2 минуты
Добавлено через 10 минут
Но если условия таковы что между типом товара и отправителем однозначное соответствие, то можно ввести этот внешний ключ, предварительно разорвав связь поставщик-поставка. По товару в поставке можно будет вытащить отправителя.[/QUOTE]

Как-то очень муторно...неужели нельзя никак по-другому сделать?

Но все равно спасибо за совет, если не найду другого решения, придется делать так.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
28.09.2013, 18:23
Помогаю со студенческими работами здесь

Внешний ключ через третью таблицу
Подскажите возможно ли такое сделать: Есть 3 таблицы 1 таблица HEAD: ID;Type 2 таблица POS: ID;Status; 3 таблица...

Как сделать внешний ключ с каскадным удалением
Здравствуйте, я новичек в этих делах, подскажите синтаксически как сделать или в моем случае изменить внешний ключ с каскадным удалением...

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

Первичный ключ заполнен в одной таблице норм, он же в другой таблице внешний NULL
Всем доброго времени суток! Проблема следующая: Использую "SQL server management studio 2012", есть бекап базы данных с которой...

Ошибка "Не удалось создать внешний ключ "
Ошибка "Не удалось создать внешний ключ "FK__Product__ID__1B29035F" со ссылочным действием SET NULL, поскольку один или несколько...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
Использование значений реквизитов справочника в документе, с определенными условиями и правами
Maks 07.04.2026
1. Контроль срока действия договора Алгоритм из решения ниже реализован на примере нетипового документа "ЗаявкаНаРаботу", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru