Поле ссылка на множество

Материал из GedeminWiki
Перейти к: навигация, поиск

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

Есть простой справочник:

CREATE TABLE USR$GOODVIEWFORM 
(
  ID	        DINTKEY NOT NULL,
  EDITIONDATE	DEDITIONDATE,
  USR$NAME	DTEXT60,
  PRIMARY       KEY (ID)
);

одна или несколько записей из которого должны отображаться в позиции пользовательского документа:

CREATE TABLE USR$PD_BREADCONTOLLINE 
(
  DOCUMENTKEY	DINTKEY NOT NULL,
  RESERVED	DINTEGER,
  MASTERKEY	DMASTERKEY,
  USR$GOODKEY	USR$GS_DGOOD,
  PRIMARY KEY   (DOCUMENTKEY)
);

Создадим домен: USR$DGOODVIEWFORM

dn0.png


dn1.png



В таблицу позиции документа добавляем поле USR$GOODVIEWFORMKEY, которое будет использовать ранее созданный домен USR$DGOODVIEWFORM

f_1.png


Переподключаемся к базе, чтобы изменения вступили в силу.


Переходим в настройки грида документа.

m1.png


В редактор коллекции TgsIBColumnEditors добавляем запись,

m2.png

где:

e1.png


Название Поле/Параметр Описание
DisplayField USR$GOODVIEWFORMKEY добавленное нами поле
EditorStyle cesSetGrid вариант отображения


Заполняем свойства Lookup:

3.png


Название Поле/Параметр Описание
Database ibdbGAdmin БД
LookupTable USR$GOODVIEWFORM таблица-справочник
gdClassName TgdcAttrUserDefined подставится автоматически, когда укажем таблицу-справочник USR$GOODVIEWFORM
LookupKeyField ID уникальный ключ из таблицы USR$GOODVIEWFORM
Transaction ibtrCommon


Для заполнения свойств LookupSet необходимо знать кросс-таблицу созданную доменом (множества). Ее можно найти на вкладке "скрипт" таблицы документа. В данном примере интересующая часть скрипта с кросс-таблицей выглядит так :

  SELECT 
    L.USR$NAME 
  FROM USR$CROSS2076_1818884808 C 
  JOIN USR$GOODVIEWFORM L ON C.USR$GOODVIEWFORMKEY = L.ID 
  WHERE C.USR$PD_BREADCONTOLLINEKEY = NEW.DOCUMENTKEY AND L.USR$NAME > ''

Вывод:

необходимая кросс-таблица USR$CROSS2076_1818884808 USR$GOODVIEWFORMKEY - поле-связка кросс таблицы со справочником USR$PD_BREADCONTOLLINEKEY - поле-связка кросс таблицы с позицией документа


Теперь заполняем свойства LookupSet:

m5.png


Название Поле/Параметр Описание
CrossTable USR$CROSS2076_1818884808 используемая кросс-таблица
CrossSourceField USR$GOODVIEWFORMKEY поле-связка кросс таблицы со справочником
CrossDestField USR$PD_BREADCONTOLLINEKEY поле-связка кросс таблицы с позицией документа
SourceTable USR$GOODVIEWFORM таблица-справочник
SourceParentField USR$GOODVIEWFORMKEY
SourceListField USR$NAME поле для отображения из таблицы-справочника
KeyField ID
SourceKeyField ID

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

m_6.png

Персональные инструменты
Пространства имён

Варианты
Действия
Навигация
Инструменты