Dataset: IDatasetModel;
Свойство Dataset определяет табличный справочник НСИ, который выступает в качестве приёмника данных.
Для выполнения примера предполагается наличие в репозитории задачи ETL с идентификатором «ETL_Task» и табличного справочника НСИ с идентификатором «RDS_DICT».
Добавьте ссылки на системные сборки: Andy, Db, Drawing, Dt, Etl, Metabase.
Sub UserProc;
Var
MB: IMetabase;
ETLTask: IEtlTask;
EtlConsumer: IEtlPlainDataConsumer;
DtRds: IDtRdsConsumer;
Begin
MB := MetabaseClass.Active;
ETLTask := MB.ItemById("ETL_Task").Edit As IEtlTask;
//Создание нового приёмника - табличного справочника НСИ
EtlConsumer := ETLTask.Create(EtlObjectType.PlainDataRdsConsumer) As IEtlPlainDataConsumer;
EtlConsumer := EtlConsumer.Edit;
EtlConsumer.ClearConsumer := False;
EtlConsumer.Id := "RDS_Consumer";
EtlConsumer.Name := "Приёмник - Табличный справочник НСИ";
//Создаем визуальный объект приёмника
CreateWX(ETLTask, EtlConsumer, 0, 0);
//Настраиваем приёмник
DtRds := EtlConsumer.Consumer As IDtRdsConsumer;
DtRds.Dataset := Mb.ItemById("RDS_DICT").Bind As IDatasetModel;
DtRds.UpdateMode := UpdateLoadMode.InsertUpdate;
//Сохранение приёмника
EtlConsumer.Save;
//Сохранение задачи
(ETLTask As IMetabaseObject).Save;
End Sub UserProc;
//Создание визуального объекта
Sub CreateWX(ETLTask: IEtlTask; ETLObject: IEtlObject; XPosition: Integer; YPosition: Integer);
Var
WxRect: IWxRectangle;
WxETLObj: IWxEtlObject;
Begin
WxRect := ETLTask.Workspace.CreateRectangle;
WxRect.Id := ETLObject.Id;
WxETLObj := New WxEtlObject.Create;
WxETLObj.EtlObject := ETLObject;
WxRect.Style.TextPosition := WxTextPosition.Bottom;
WxRect.Style.PictureMarginTop := -10;
WxRect.PinPosition := New GxPointF.Create(XPosition, YPosition);
WxRect.Extension := WxETLObj As IWxShapeExtension;
End Sub CreateWX;
При выполнении примера в задаче ETL будет создан новый приёмник данных, связанный с указанным табличным справочником НСИ.
См. также: