DateLevels: Array;
DateLevels: Array;
Свойство DateLevels возвращает список уровней календаря, по которым в источнике имеются данные.
Каждый элемент массива содержит числовое значение, обозначающее уровень. Для проверки значений можно воспользоваться перечислением DimCalendarLevel.
Предполагается, что репозиторий настроен на работу с поисковым сервисом на базе Apache Solr. В базе поискового сервиса имеются индексированные данные о срезах различных источников данных репозитория. Подключите системные сборки: BISearch, Fore, Metabase.
Sub UserProc;
Var
MB: IMetabase;
SharedParams: ISharedParams;
SearchEngine: ISolrSearchEngineService;
Schema: ISolrSearchEngineSchema;
SearchExecutor: ISearchExecutor;
SearchContext: ISolrSourceDataSearchContext;
Results: ISolrSearchResults;
Result: ISearchSourceDataResult;
i: Integer;
s: String;
Begin
MB := MetabaseClass.Active;
//Параметры поиска и индексации, заданные для репозитория
SharedParams := MB.SpecialObject(MetabaseSpecialObject.SharedParams).Bind As ISharedParams;
SearchEngine := SharedParams.SearchEngine As ISolrSearchEngineService;
Schema := SearchEngine.SearchEngineSchema As ISolrSearchEngineSchema;
//Параметры поиска
SearchExecutor := Schema.SearchExecutor(SearchEngineTargetType.SourceData);
SearchContext := SearchExecutor.CreateContext As ISolrSourceDataSearchContext;
SearchContext.Locale := LocaleCodeID.Russian;
SearchContext.Text := "2000";
//Поиск
Results := SearchExecutor.Search(SearchContext) As ISolrSearchResults;
//Просмотр информации по источнику для первого результата поиска
Result := Results.Item(0) As ISearchSourceDataResult;
Debug.WriteLine("Наименование среза: " + Result.Name);
Debug.WriteLine("Уровни календаря, по которым имеются данные:");
Debug.Indent;
For Each i In Result.DateLevels Do
Select Case i
Case 1: Debug.WriteLine("Годы");
Case 2: Debug.WriteLine("Полугодия");
Case 3: Debug.WriteLine("Кварталы");
Case 4: Debug.WriteLine("Месяцы");
Case 5: Debug.WriteLine("Дни");
Case 6: Debug.WriteLine("9 месяцев");
Case 7: Debug.WriteLine("Недели");
End Select;
End For;
Debug.Unindent;
Debug.WriteLine("Список годов, по которым имеются данные:");
For Each s In Result.Time Do
Debug.Write(s + ' ');
End For;
Debug.WriteLine("");
If Result.HighlightedTime.Length > 0 Then
Debug.WriteLine("Список годов с подсветкой искомого значения:");
For Each s In Result.HighlightedTime Do
Debug.Write(s + ' ');
End For;
Debug.WriteLine("");
End If;
If Result.HighlightedFreeDimensions.Length > 0 Then
Debug.WriteLine("Список свободных измерений с подсветкой искомого значения:");
For Each s In Result.HighlightedFreeDimensions Do
Debug.Write(s + ' ');
End For;
Debug.WriteLine("");
End If;
End Sub UserProc;
При выполнении примера будет осуществлен поиск указанного значения по индексированной информации об элементах измерений. Из первого найденного результата будет получена информация о календарном периоде, за который имеются данные. Данная информация будет выведена в консоль среды разработки. Также будет выведена информация о свободных измерения, если они имеются.
Необходимые требования и результат выполнения примера Fore.NET совпадают с примером Fore. Кроме сборок, указанных в примере Fore, подключите также сборку «ForeSystem».
Imports Prognoz.Platform.Interop.BISearch;
Imports Prognoz.Platform.Interop.ForeSystem;
Imports Prognoz.Platform.Interop.KeFore;
Imports Prognoz.Platform.Interop.Metabase;
Public Shared Sub Main(Params: StartParams);
Var
MB: IMetabase;
SharedParams: ISharedParams;
SearchEngine: ISolrSearchEngineService;
Schema: ISolrSearchEngineSchema;
SearchExecutor: ISearchExecutor;
SearchContext: ISolrSourceDataSearchContext;
Results: ISolrSearchResults;
Result: ISearchSourceDataResult;
i: Integer;
s: String;
Begin
MB := Params.Metabase;
//Параметры поиска и индексации, заданные для репозитория
SharedParams := MB.SpecialObject[MetabaseSpecialObject.msoSharedParams].Bind() As ISharedParams;
SearchEngine := SharedParams.SearchEngine As ISolrSearchEngineService;
Schema := SearchEngine.SearchEngineSchema As ISolrSearchEngineSchema;
//Параметры поиска
SearchExecutor := Schema.SearchExecutor[SearchEngineTargetType.settSourceData];
SearchContext := SearchExecutor.CreateContext() As ISolrSourceDataSearchContext;
SearchContext.Locale := LocaleCodeID.lcidRussian;
SearchContext.Text := "2000";
//Поиск
Results := SearchExecutor.Search(SearchContext) As ISolrSearchResults;
//Просмотр информации по источнику для первого результата поиска
Result := Results.Item[0] As ISearchSourceDataResult;
System.Diagnostics.Debug.WriteLine("Наименование среза: " + Result.Name);
System.Diagnostics.Debug.WriteLine("Уровни календаря, по которым имеются данные:");
System.Diagnostics.Debug.Indent();
For Each i In Result.DateLevels Do
Select Case i
Case 1: System.Diagnostics.Debug.WriteLine("Годы");
Case 2: System.Diagnostics.Debug.WriteLine("Полугодия");
Case 3: System.Diagnostics.Debug.WriteLine("Кварталы");
Case 4: System.Diagnostics.Debug.WriteLine("Месяцы");
Case 5: System.Diagnostics.Debug.WriteLine("Дни");
Case 6: System.Diagnostics.Debug.WriteLine("9 месяцев");
Case 7: System.Diagnostics.Debug.WriteLine("Недели");
End Select;
End For;
System.Diagnostics.Debug.Unindent();
System.Diagnostics.Debug.WriteLine("Список годов, по которым имеются данные:");
For Each s In Result.Time Do
System.Diagnostics.Debug.Write(s + ' ');
End For;
System.Diagnostics.Debug.WriteLine("");
If Result.HighlightedTime.Length > 0 Then
System.Diagnostics.Debug.WriteLine("Список годов с подсветкой искомого значения:");
For Each s In Result.HighlightedTime Do
System.Diagnostics.Debug.Write(s + ' ');
End For;
System.Diagnostics.Debug.WriteLine("");
End If;
If Result.HighlightedFreeDimensions.Length > 0 Then
System.Diagnostics.Debug.WriteLine("Список свободных измерений с подсветкой искомого значения:");
For Each s In Result.HighlightedFreeDimensions Do
System.Diagnostics.Debug.Write(s + ' ');
End For;
System.Diagnostics.Debug.WriteLine("");
End If;
End Sub;
См. также: