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

Уникальность первичного ключа внутри трех таблиц

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



Зарегистрирован: 04.02.2005
Сообщения: 2
Откуда: Пермь-Москва

СообщениеДобавлено: Пт Фев 04 2005 12:26    Заголовок сообщения: Уникальность первичного ключа внутри трех таблиц Ответить с цитатой

Обращаюсь к Вашему опыту, господа и дамы, разработчики БД!
Проблема в следующем: имеется три таблицы (СУБД PostgreSQL), возникла необходимость, чтобы первичные ключи этих таблиц непересекались по значению, т.е. уникальность их первичных ключей была не только в своей таблице, но и в двух остальных. Т.е. получается, как бы один первичный ключ на три таблицы. Какие есть способы реализации этого на уровне СУБД? Желательно "законные". "Обходным путем" можно завести последовательность и при каждом insert насильно присваивать полям таблицы ее значение... Может у кого-нибудь будут другие идеи?
И еще один вопрос: само возникновение такой пролемы не говорит о неверном проектировании структуры? Кто-нибудь сталкивался с подобным?

Заранее благодарен!
Дмитрий.
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
dr_brick



Зарегистрирован: 03.02.2005
Сообщения: 8
Откуда: Москва

СообщениеДобавлено: Пт Фев 04 2005 16:39    Заголовок сообщения: Re: Уникальность первичного ключа внутри трех таблиц Ответить с цитатой

с PostgreSQL к сожалению не работал
1. в interbase это легко реализуется с помощью генератора и хранимой процедуры (очень удобный механизм), если же в PostgreSQL генераторов (или подобного) нет, то можно:
2. попробовать создать ещё одно поле значение котороо для каждой таблицы задавать как (Primary key)*3 + n, где n=0..2 - номер соответствующей таблицы (не самое наверное красивое решение и работать будет только если при вставке уже известно значение ключевого поля - т.е. надо проверять)
3. а может - просто добавить поле с номером таблицы и внешние все связи осуществлять по двум полям (но соответсвенно эти два поля должны быть во всех подчинённых таблицах и во всех запросах)

а насчёт неверно спроектированной структуры - вполне вероятно хотя это зависит от конкректной задачи
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
jeth



Зарегистрирован: 04.02.2005
Сообщения: 2
Откуда: Пермь-Москва

СообщениеДобавлено: Пт Фев 04 2005 16:52    Заголовок сообщения: Ответить с цитатой

Спасибо, dr_brick!
Я решил проблему средствами PostgreSQL: там есть понятие последовательности, через которые СУБД автоматически реализует все первичные ключи. Я завел последовательность и насильно прикрутил ее ко всем первичным ключам этих трех таблиц. Решение сработало!

Дмитрий.
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
Показать сообщения:   
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Базы данных Часовой пояс: 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
Внимание! Любой из материалов, опубликованных на этом сервере, не может быть воспроизведен в какой бы то ни было форме и какими бы то ни было средствами без письменного разрешения владельцев авторских прав. Подробнее...