Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2006.09.10;
Скачать: CL | DM;

Вниз

Помогите определить связи   Найти похожие ветки 

 
freak   (2006-07-06 18:00) [0]

Доброго времени суток.

Задача: Имеется таблица сущностей. Некоторые сущности могут при определенных условиях "заменять" другие (не в самой таблице, а как бы... хм... в реальной жизни). Причем есть такие, которые заменяются не одной, а сразу несколькими. Например, при продаже... есть номенклатура книга (1шт.), включающаяя в себя несколько томов, которая в случае отсутствия на складе может быть заменена несколькими книгами по одному тому. Как определить подобную связь в БД?

Заранее благодарен.


 
Ega23 ©   (2006-07-06 18:04) [1]

Сделать ещё одну таблицу со связью "многие-ко-многим" на данную таблицу.


 
freak   (2006-07-06 18:08) [2]

Под конец дня че-т туго соображается, можно проиллюстрировать? Если не затруднит конечно =/


 
Ega23 ©   (2006-07-06 18:14) [3]



alter table GoodSubstitutes
  drop constraint FK_GOODSUBS_REF_GOODS
go

alter table GoodSubstitutes
  drop constraint FK_GOODSUBS_REF2_GOODS
go

if exists (select 1
           from  sysobjects
          where  id = object_id("GoodSubstitutes")
           and   type = "U")
  drop table GoodSubstitutes
go

if exists (select 1
           from  sysobjects
          where  id = object_id("Goods")
           and   type = "U")
  drop table Goods
go

/*==============================================================*/
/* Table: GoodSubstitutes                                       */
/*==============================================================*/
create table GoodSubstitutes (
  UNID                 Int Identity(0,1)              not null,
  GoodID               int                            null,
  SubstGoodID          int                            null
)
go

/*==============================================================*/
/* Table: Goods                                                 */
/*==============================================================*/
create table Goods (
  GoodID               int                            not null,
  GoodName             varchar(255)                   not null,
  constraint PK_GOODS primary key  (GoodID)
)
go

alter table GoodSubstitutes
  add constraint FK_GOODSUBS_REF_GOODS foreign key (GoodID)
     references Goods (GoodID)
go

alter table GoodSubstitutes
  add constraint FK_GOODSUBS_REF2_GOODS foreign key (SubstGoodID)
     references Goods (GoodID)
go

Print "===  Cоздание  объектов  БД завершено"
go


 
Ega23 ©   (2006-07-06 18:16) [4]

В таком вот акцепте. На большее уж извини - сейчас времени вообще нет...

В принципе, это скрипт на создание структур таблиц.
Думаю разберёшься.


 
Desdechado ©   (2006-07-07 10:31) [5]

Пришел купить энциклопедию в 10 томах, а мне дали 5 томов Есенина и 5 сборников кроссвордов?
что-то мне это напоминает...



Страницы: 1 вся ветка

Текущий архив: 2006.09.10;
Скачать: CL | DM;

Наверх




Память: 0.48 MB
Время: 0.034 c
6-1145597801
ms_odin
2006-04-21 09:36
2006.09.10
Анализ и обработка служебной информации


5-1139301255
Priest
2006-02-07 11:34
2006.09.10
Делегирование реализации интерфейсов


3-1151919542
Mishenka
2006-07-03 13:39
2006.09.10
База видна только на компьютерах, на которых установлена Delphi


2-1156214930
Ref
2006-08-22 06:48
2006.09.10
Отчет


2-1155782970
Broz
2006-08-17 06:49
2006.09.10
Поиск