Logo Море(!) аналитической информации!
IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware
Архив форумов ЦИТФорума
Море(!) вопросов - Море(!) ответов
 
 FAQFAQ   ПоискПоиск   ПользователиПользователи   ГруппыГруппы   РегистрацияРегистрация 
 ПрофильПрофиль   Войти и проверить личные сообщенияВойти и проверить личные сообщения   ВходВход 
Как правильно задавать вопросы

как правильно связать две таблицы?

 
Перейти:  
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Базы данных
Предыдущая тема :: Следующая тема  
Автор Сообщение
cknd
Гость





СообщениеДобавлено: Вт Сен 23 2003 08:53    Заголовок сообщения: как правильно связать две таблицы? Ответить с цитатой

Объясните пожалуйста!
WORKER(ID, NAME, SKILL_ID)
SKILL(SKILL_ID, SKILLNAME)
внешний ключ: SKILL_ID
в данном случае все ясно, в таблице worker хранится skill_id по которому можно идентифицировать skillname. Но поскольку skillname тоже является потенциальным ключом (значения не повторяются) то можно сделать:
WORKER(ID, NAME, SKILLNAME)
SKILL(SKILLNAME)
внешний ключ: SKILLNAME.
Соответственно вопрос, что из этого правильно, и почему?
Вернуться к началу
and3008



Зарегистрирован: 12.10.2001
Сообщения: 14893
Откуда: Н.Новгород

СообщениеДобавлено: Вт Сен 23 2003 09:07    Заголовок сообщения: Объясняю (+) Ответить с цитатой

В первом случае достигается уникальность записей на основе цифрового ключа.

Во втором случае все полетит к чертовой матери, когда появятся неуникальные значения SKILLNAME.

Я не знаю требований к реляционной модели вашей БД, поэтому дальнейшие рекомендации давать глупо.
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
cknd
Гость





СообщениеДобавлено: Вт Сен 23 2003 10:04    Заголовок сообщения: Re: Объясняю (+) Ответить с цитатой

сорри, торможу с утра, на самом деле проблемма в другом, но это уже иная история...
Вернуться к началу
Показать сообщения:   
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Базы данных Часовой пояс: GMT + 3
Страница 1 из 1

 
Перейти:  
Вы не можете начинать темы
Вы не можете отвечать на сообщения
Вы не можете редактировать свои сообщения
Вы не можете удалять свои сообщения
Вы не можете голосовать в опросах


Powered by phpBB © 2001, 2002 phpBB Group
Русская поддержка phpBB

 

IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware

Информация для рекламодателей PR-акции, размещение рекламы — adv@citforum.ru,
тел. +7 495 6608306, ICQ 232284597
Пресс-релизы — pr@citforum.ru
Послать комментарий
Информация для авторов
This Web server launched on February 24, 1997
Copyright © 1997-2000 CIT, © 2001-2006 CIT Forum
Внимание! Любой из материалов, опубликованных на этом сервере, не может быть воспроизведен в какой бы то ни было форме и какими бы то ни было средствами без письменного разрешения владельцев авторских прав. Подробнее...