IDatasetDataArrayProvider.AttachArray

Синтаксис Fore

AttachArray(Value: Array);

Синтаксис Fore.NET

AttachArray(Value: System.Array);

Параметры

Value. Массив, из которого будут загружены данные.

Описание

Метод AttachArray загружает данные из массива в источник данных.

Комментарии

Размерность массива должна соответствовать количеству и размеру полей, которые созданы в источнике данных.

Пример Fore

Для выполнения примера предполагается наличие в репозитории базы данных временных рядов с идентификатором «FC». В данной базе создан атрибут, ссылающийся на справочник НСИ с идентификатором «COUNTRY». Справочник создан в репозитории НСИ с идентификатором «RDS». В справочнике НСИ создан дополнительный целочисленный атрибут Code. Также в справочнике НСИ созданы элементы со следующими значениями атрибутов:

В справочнике единиц измерения создан элемент с ключом «69». В базе данных временных рядов используется годовая динамика.

Function OpenArrayProvider: IDatasetDataArrayProvider;
Var
    ArrayProvider: IDatasetDataArrayProvider;
    Arr: Array Of Variant;
    TField: ITableField;
    Row: Integer = 1000//Количество строк с данными
Begin
    Arr := New Variant[Row, 5];
    Arr[00] := 1; Arr[01] := "Россия"; Arr[02] := 69; Arr[03] := "1997A1"; Arr[04] := 11.178;
    Arr[10] := 1; Arr[11] := "Россия"; Arr[12] := 69; Arr[13] := "1998A1"; Arr[14] := 20.123;
    Arr[20] := 1; Arr[21] := "Россия"; Arr[22] := 69; Arr[23] := "1999A1"; Arr[24] := 21.67;
    Arr[30] := 1; Arr[31] := "Россия"; Arr[32] := 69; Arr[33] := "2000A1"; Arr[34] := 22.458;
    Arr[40] := 1; Arr[41] := "Россия"; Arr[42] := 69; Arr[43] := "2001A1"; Arr[44] := 23.178;
    Arr[50] := 2; Arr[51] := "США"; Arr[52] := 69; Arr[53] := "1997A1"; Arr[54] := 22.167;
    Arr[60] := 2; Arr[61] := "США"; Arr[62] := 69; Arr[63] := "1998A1"; Arr[64] := 25.12;
    //Остальные данные...
    ArrayProvider := New DatasetDataArrayProvider.Create;
    ArrayProvider.AddField("Code", DbDataType.Integer);
    ArrayProvider.AddField("Country", DbDataType.String);
    ArrayProvider.AddField("Units", DbDataType.Integer);
    ArrayProvider.AddField("Year", DbDataType.String);
    ArrayProvider.AddField("Value", DbDataType.Float);
    ArrayProvider.AttachArray(Arr);
    Return ArrayProvider;
End Function OpenArrayProvider;

Sub LoadDataFromArray;
Var
    Mb: IMetabase;
    RubDesc, NSIDesc: IMetabaseObjectDescriptor;
    CubeMetaLoader: ICubeMetaLoader;
    CrInfo: IMetabaseObjectCreateInfo;
    Obj: IMetabaseObject;
    ObjDesc: IMetabaseObjectDescriptor;
    Bindings: ICubeMetaLoaderBindings;
    Binding: ICubeMetaLoaderBinding;
Begin
    Mb := MetabaseClass.Active;
    RubDesc := Mb.ItemById("FC");
    NSIDesc := Mb.ItemById("RDS");

    // Объект импорта
    CrInfo := Mb.CreateCreateInfo;
    CrInfo.ClassId := MetabaseObjectClass.KE_CLASS_CUBEMETALOADER;
    CrInfo.Id := "CUBEMETALOADER";
    CrInfo.Permanent := False;
    CrInfo.Parent := RubDesc;
    ObjDesc := Mb.CreateObject(CrInfo);
    Obj := ObjDesc.Edit;
    CubeMetaLoader := Obj As ICubeMetaLoader;

    //Привязка атрибутов
    Bindings := CubeMetaLoader.Bindings;
    
    Binding := Bindings.Add;
    Binding.BindingType := CubeMetaLoaderBindingType.Attribute;
    Binding.Attribute := "COUNTRY";
    Binding.FieldType := CubeMetaLoaderFieldType.Index;
    Binding.Field := "0";
    Binding.CheckField := "1";
    Binding.Dimension := Mb.ItemByIdNamespace("COUNTRY", NsiDesc.Key).Bind As IDimensionModel;
    Binding.Index := "UNIQUEKEY";
    Binding.KeyAttribute := "KEY";
    Binding.NameAttribute := "NAME";
    
    Binding := Bindings.Add;
    Binding.BindingType := CubeMetaLoaderBindingType.Unit;
    Binding.FieldType := CubeMetaLoaderFieldType.Index;
    Binding.Field := "2";
    Binding.Dimension := Mb.ItemByIdNamespace("UNITS", NSIDesc.Key).Bind As IDimensionModel;
    Binding.Index := "PRIMARY_INDEX";
    Binding.KeyAttribute := "KEY";

    Binding := Bindings.Add;
    Binding.BindingType := CubeMetaLoaderBindingType.Calendar;
    Binding.CalendarOptions.Levels := DimCalendarLevelSet.Year;
    Binding.ByColumns := False;
    Binding.CalendarDateFormat := "$Year$A1";
    Binding.FieldType := CubeMetaLoaderFieldType.Index;
    Binding.Field := "3";
    
    Binding := Bindings.Add;
    Binding.BindingType := CubeMetaLoaderBindingType.Value;
    Binding.FieldType := CubeMetaLoaderFieldType.Index;
    Binding.Field := "4";

    Binding := Bindings.Add;
    Binding.BindingType := CubeMetaLoaderBindingType.Attribute;
    Binding.Attribute := "DL";
    Binding.FieldType := CubeMetaLoaderFieldType.ConstValue;
    Binding.FieldValue := DimCalendarLevel.Year;
    
    //Настройки загрузчика
    CubeMetaLoader.LoadType := CubeMetaLoaderLoadType.CreateAndUpdate;
    CubeMetaLoader.Rubricator := RubDesc.Bind As IRubricator;
    CubeMetaLoader.Data := OpenArrayProvider;
    CubeMetaLoader.LoadData;
End Sub LoadDataFromArray;

Функция «OpenArrayProvider» реализует пользовательский источник данных, загружающий данные из массива. При выполнении процедуры «LoadDataFromArray» будет создан загрузчик показателей. Будут настроены параметры привязки атрибутов, а также в качестве источника данных будет указан пользовательский источник данных. После этого будет произведена загрузка данных.

Пример Fore.NET

Для выполнения примера предполагается наличие в репозитории базы данных временных рядовс идентификатором «FC». В данной базе создан атрибут, ссылающийся на справочник НСИ с идентификатором «COUNTRY». Справочник создан в репозитории НСИ с идентификатором «RDS». В справочнике НСИ создан дополнительный целочисленный атрибут Code. Также в справочнике НСИ созданы элементы со следующими значениями атрибутов:

В справочнике единиц измерения создан элемент с ключом «69». В базе данных временных рядов используется годовая динамика.

Public Class Program

    Shared Function OpenArrayProvider(): IDatasetDataArrayProvider;
    Var
        ArrayProvider: IDatasetDataArrayProvider;
        Arr: Array;
        TField: ITableField;
        Row: Integer = 1000//Количество строк с данными
    Begin
        Arr := New Object[5, Row];
        Arr[00] := 1; Arr[01] := "Россия"; Arr[02] := 69; Arr[03] := "1997A1"; Arr[04] := 11.178;
        Arr[10] := 1; Arr[11] := "Россия"; Arr[12] := 69; Arr[13] := "1998A1"; Arr[14] := 20.123;
        Arr[20] := 1; Arr[21] := "Россия"; Arr[22] := 69; Arr[23] := "1999A1"; Arr[24] := 21.67;
        Arr[30] := 1; Arr[31] := "Россия"; Arr[32] := 69; Arr[33] := "2000A1"; Arr[34] := 22.458;
        Arr[40] := 1; Arr[41] := "Россия"; Arr[42] := 69; Arr[43] := "2001A1"; Arr[44] := 23.178;
        Arr[50] := 2; Arr[51] := "США"; Arr[52] := 69; Arr[53] := "1997A1"; Arr[54] := 22.167;
        Arr[60] := 2; Arr[61] := "США"; Arr[62] := 69; Arr[63] := "1998A1"; Arr[64] := 25.12;
        //Остальные данные...
        ArrayProvider := New DatasetDataArrayProviderClass();
        ArrayProvider.AddField("Code", DbDataType.ddtInteger);
        ArrayProvider.AddField("Country", DbDataType.ddtString);
        ArrayProvider.AddField("Units", DbDataType.ddtInteger);
        ArrayProvider.AddField("Year", DbDataType.ddtString);
        ArrayProvider.AddField("Value", DbDataType.ddtFloat);
        ArrayProvider.AttachArray(Arr);
        Return ArrayProvider;
    End Function OpenArrayProvider;
    
    [STAThread]
    Public Shared Sub Main(Params: StartParams);
    Var
        Mb: IMetabase;
        RubDesc, NSIDesc: IMetabaseObjectDescriptor;
        CubeMetaLoader: ICubeMetaLoader;
        CrInfo: IMetabaseObjectCreateInfo;
        Obj: IMetabaseObject;
        ObjDesc: IMetabaseObjectDescriptor;
        Bindings: ICubeMetaLoaderBindings;
        Binding: ICubeMetaLoaderBinding;
    Begin
        Mb := Params.Metabase;
        RubDesc := Mb.ItemById["FC"];
        NSIDesc := Mb.ItemById["RDS"];
    
        // Объект импорта
        CrInfo := Mb.CreateCreateInfo();
        CrInfo.ClassId := MetabaseObjectClass.KE_CLASS_CUBEMETALOADER As Int32;
        CrInfo.Id := "CUBEMETALOADER";
        CrInfo.Permanent := False;
        CrInfo.Parent := RubDesc;
        ObjDesc := Mb.CreateObject(CrInfo);
        Obj := ObjDesc.Edit();
        CubeMetaLoader := Obj As ICubeMetaLoader;
    
        //Привязка атрибутов
        Bindings := CubeMetaLoader.Bindings;
        
        Binding := Bindings.Add();
        Binding.BindingType := CubeMetaLoaderBindingType.cmlbtAttribute;
        Binding.Attribute := "COUNTRY";
        Binding.FieldType := CubeMetaLoaderFieldType.cmlftIndex;
        Binding.Field := "0";
        Binding.CheckField := "1";
        Binding.Dimension := Mb.ItemByIdNamespace["COUNTRY", NsiDesc.Key].Bind() As IDimensionModel;
        Binding.Index := "UNIQUEKEY";
        Binding.KeyAttribute := "KEY";
        Binding.NameAttribute := "NAME";
        
        Binding := Bindings.Add();
        Binding.BindingType := CubeMetaLoaderBindingType.cmlbtUnit;
        Binding.FieldType := CubeMetaLoaderFieldType.cmlftIndex;
        Binding.Field := "2";
        Binding.Dimension := Mb.ItemByIdNamespace["UNITS", NSIDesc.Key].Bind() As IDimensionModel;
        Binding.Index := "PRIMARY_INDEX";
        Binding.KeyAttribute := "KEY";
    
        Binding := Bindings.Add();
        Binding.BindingType := CubeMetaLoaderBindingType.cmlbtCalendar;
        Binding.CalendarOptions.Levels := DimCalendarLevelSet.dclsYear;
        Binding.ByColumns := False;
        Binding.CalendarDateFormat := "$Year$A1";
        Binding.FieldType := CubeMetaLoaderFieldType.cmlftIndex;
        Binding.Field := "3";
        
        Binding := Bindings.Add();
        Binding.BindingType := CubeMetaLoaderBindingType.cmlbtValue;
        Binding.FieldType := CubeMetaLoaderFieldType.cmlftIndex;
        Binding.Field := "4";
    
        Binding := Bindings.Add();
        Binding.BindingType := CubeMetaLoaderBindingType.cmlbtAttribute;
        Binding.Attribute := "DL";
        Binding.FieldType := CubeMetaLoaderFieldType.cmlftConstValue;
        Binding.FieldValue := DimCalendarLevel.dclYear;
        
        //Настройки загрузчика
        CubeMetaLoader.LoadType := CubeMetaLoaderLoadType.cmlltCreateAndUpdate;
        CubeMetaLoader.Rubricator := RubDesc.Bind() As IRubricator;
        CubeMetaLoader.Data := OpenArrayProvider();
        CubeMetaLoader.LoadData();
    End Sub;

End Class;

Функция «OpenArrayProvider» реализует пользовательский источник данных, загружающий данные из массива. При выполнении процедуры «Main» будет создан загрузчик показателей. Будут настроены параметры привязки атрибутов, а также в качестве источника данных будет указан пользовательский источник данных. После этого будет произведена загрузка данных.

См. также:

IDatasetDataArrayProvider