Форум программистов, компьютерный форум, киберфорум
C++ Builder: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.57/7: Рейтинг темы: голосов - 7, средняя оценка - 4.57
1 / 1 / 1
Регистрация: 24.04.2009
Сообщений: 12

Связи между таблицами в 3НФ

27.04.2009, 13:42. Показов 1491. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Пусть имеется отношение R(A1,A2,...An) приводим его в 3НФ. Получаем набор отношений: R1(..), R2(..)..Между полученными отношениями надо задать связи, чтоб это была действительно схема БД, а не разрозненный набор отношений.Заготовки уже есть: атрибуты с одинаковыми именами в разных отношениях. Например: ПОКУПАТЕЛИ(КОД_ПОКУПАТЕЛЯ,...), ТОВАР(КОД_ТОВАРА,КОД_ПОКУПАТЕЛЯ). Но просто так атрибуты не соединить: тип связи может оказаться неопределенн. Как быть?

Возможный вариант. Пусть есть 2а отношения: R1(K1,..) R2(K2,...). Ключи K1, K2 могут быть составными. Если в R2 есть атрибуты с именами как в K1=>связь должна быть, если они ключ, то 1:1, нет=>1:N.

Верно ли это?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
27.04.2009, 13:42
Ответы с готовыми решениями:

Связи между таблицами
Помогите разобраться с базами данных. В этом я новичок, но хотелось бы разобраться с этим. Стоит задача организовать базу данных в...

Связи между таблицами в Билдере
Есть проблемка зделал пару таблиц связал их ключом. вывел в билдер но мне нуно чтобы я мог в первой таблице выбирать ключевой атрибут...

Наладить связи между практически одинаковыми таблицами таблицами
Помогите пожалуйста со следующей затыкой. Выбираю "Схема данных". Там открыты три таблицы. Одна материнская (откуда идет номер модели)...

2
Комбайнёр
 Аватар для MAcK
1606 / 704 / 77
Регистрация: 27.05.2008
Сообщений: 2,535
27.04.2009, 19:40
Что есть ЗНФ?
Вам это нужно сделать программно или в самой БД?
0
1 / 1 / 1
Регистрация: 24.04.2009
Сообщений: 12
28.04.2009, 09:49  [ТС]
3НФ - третья нормальная форма. Как правило таблицы в БД стараются привести в 3НФ, чтобы избежать аномалий удаления, добавления и т.п (аномалия это когда БД попадает в противоречивое состояние). На самом деле думаю этот момент не принципиальный(просто старался быть точным). Есть набор таблиц, нужно их связать. Сделать нужно програмно, понятно, что sql запросом на создание foreign key, через ADO например. Вопрос не в том, что я знаю как это сделать руками и не знаю как програмно. Какие поля каких таблиц нужно соединять?

Пример:

R(A,B,C) A->B

приводим в 3НФ получаем:

R1(A,B) R2(A,C)

Если просто создать таблицы R1 и R2, то мы получим 2е независимых таблицы,такой набор таблиц не эквивалентен исходному, а если мы их свяжем(сделаем поле А foreign key), то эквивалентность будет.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
28.04.2009, 09:49
Помогаю со студенческими работами здесь

Связи между таблицами
Здравствуйте! Я создала таблицы и целостность между ними удалила. Теперь надо написать триггер или процедуру хранимую, чтобы при добавлении...

Связи между таблицами
помогите пожалуйста! не могу никак связать таблицы в mysql workbench, все время да будет какая нибудь ошибка

Связи между таблицами
использую VS win forms и sql server, где лучше хранить связи таблиц? на sql server?

Связи между таблицами
Здравствуйте, помогите пожалуйста, сделать связи между таблицами. У меня выбивает ошибку "Выражение неверно введено или является...

Связи между таблицами
Знающие ребята, подскажите пожалуйста, правильно ли я связал следующие таблицы? Или же эти связи в sql server management бесполезны?...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Уведомление о неверно выбранном значении справочника
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 существует уже давно, и также давно существуют скрипты под нее. Тем не менее, прога живет, периодически что-то не спеша дополняется, улучшается. Что меня в первую очередь. . .
Отображение реквизитов в документе по условию и контроль их заполнения
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеСпецтехники", разработанного в конфигурации КА2. Данный документ берёт данные из другого нетипового документа. . .
Фото всей Земли с борта корабля Orion миссии Artemis II
kumehtar 04.04.2026
Это первое подобное фото сделанное человеком за 50 лет. Снимок называют новым вариантом легендарной фотографии «The Blue Marble» 1972 года, сделанной с борта корабля «Аполлон-17». Новое фото. . .
Вывод диалогового окна перед закрытием, если документ не проведён
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать программный контроль на предмет проведения документа. . .
Программный контроль заполнения реквизитов табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: 1. Реализовать контроль заполнения реквизита. . .
wmic не является внутренней или внешней командой
Maks 02.04.2026
Решение: DISM / Online / Add-Capability / CapabilityName:WMIC~~~~ Отсюда: https:/ / winitpro. ru/ index. php/ 2025/ 02/ 14/ komanda-wmic-ne-naydena/
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru