MbElementDependencyTemplateClass.CreateByDictionary

Syntax

CreateByDictionary(DictionaryKey: Integer);

Parameters

DictionaryKey. MDM dictionary key.

Description

The CreateByDictionary constructor creates a new dependencies template in accordance with MDM dictionary parameters.

Comments

To get a dictionary key, use the IMetabaseObjectDescriptor.Key property or the IMetabase.GetObjectKeyById method.

Example

Executing the example requires that the repository contains an object with the Obj_1 identifier and an MDM dictionary with the Country identifier. Tracking of dependencies from MDM dictionary elements is enabled for an object. The dictionary is stored in the MDM repository with the RDS identifier.

Sub UserProc;
Var
    MB: IMetabase;
    Obj, Dictionary: IMetabaseObjectDescriptor;
    Elements: IRdsDictionaryElements;
    Depends: IMbElementDependencies;
    Template: IMbElementDependencyTemplate;
    ElemKeys: Array Of Integer;
Begin
    MB := MetabaseClass.Active;
    Obj := MB.ItemById("Obj_1");
    Dictionary := MB.ItemByIdNamespace("Country", MB.ItemById("RDS").Key);
    Elements := (Dictionary.Open(NullAs IRdsDictionaryInstance).Elements;
    Template := New MbElementDependencyTemplateClass.CreateByDictionary(Dictionary.Key);
    ElemKeys := New Integer[2];
    ElemKeys[0] := Elements.Element(1);
    ElemKeys[1] := Elements.Element(2);
    Template.ElementKeys := ElemKeys;
    //Collection of object dependencies
    Depends := Obj.ElementDependencies;
    Depends.Add(Template);
    Mb.ElementDependenciesDatabase.Update(Depends);
End Sub UserProc;

Executing the example results in a collection of object dependencies from MDM dictionary elements. Two dependencies from two dictionary elements will be added to a list of dependencies. The list of dependencies will be saved in the repository database.

See also:

MbElementDependencyTemplateClass