CheckPeriods;
Метод CheckPeriods осуществляет проверку на наличие формул с пересекающимися периодами действия.
Данный метод может использоваться, если осуществляется редактирование периодов действия формул напрямую в таблице формул многомерного расчета на сервере БД.
Для выполнения примера предполагается наличие в репозитории многомерного расчета на сервере БД с идентификатором "MDCalc_1". Для формул включена зависимость от времени.
Sub Main;
Var
MB: IMetabase;
MDInst: IMDCalculationInstance;
Source: IMDCalculationSourceInstance;
Dest: IMDCalculationDestinationInstance;
Slices: IMDCalculationSlicesInstance;
Formulas: IMDCalculationFormulas;
DestCoo: IMatrixCoord;
ElementKey: IMDCalculationFormulaElementKey;
i: Integer;
Begin
MB := MetabaseClass.Active;
MDInst := MB.ItemById("MDCalc_1").Open(Null) As IMDCalculationInstance;
Dest := MDInst.Destination;
DestCoo := Dest.NewCoord;
Slices := Dest.Slices;
For i := 0 To Slices.Count - 1 Do
DestCoo.Item(i) := 0;
End For;
ElementKey := Dest.CoordToKey(DestCoo);
ElementKey.FactIndex := 0;
Source := MDInst.Sources.Item(0);
Slices := Source.Slices;
Formulas := MDInst.ReadFormulas(ElementKey);
Try
Formulas.CheckPeriods;
Debug.WriteLine("Периоды действия формул корректны");
Except On Err: Exception Do
Debug.WriteLine("Ошибка в периодах действия формул. ");
Debug.WriteLine(Err.Message);
End Try;
End Sub Main;
После выполнения примера будет осуществлена проверка на наличие пересекающихся периодов действия формул по указанной координате. В случае наличия пересекающихся периодов - генерируется исключительная ситуация, текст ошибки выводится в консоль среды разработки.
См. также: