Зачем нужен парсер файлов технологического журнала?
Читать данные в текстовом виде не слишком удобно, особенно если нам нужно найти какое-либо определенное событие. Например, текст SQL запроса среди тысяч записей в десятках папок с идентификаторами рабочих процессов.
Кроме того иногда бывает необходимо автоматизировать сбор информации из логов ТЖ на периодической основе и проанализировать информацию из них за большой период времени.
В приложенных файлах приведен листинг функции, которая отбирает события DBMSSQL из логов ТЖ, остальные события пропускаются. Вы можете переопределить это в тексте модуля, учитывая что число колонок для различных событий может отличаться.
Функция написана на C# и может использовать все расширения классов .NET.
Как это работает ?
Вы открываете SQL Server Management Studio (SSMS), выбираете New Query и набираете следующий текст:
select * from ParseLogFiles({сетевой каталог с файлами ТЖ})
Функция возвращает вам таблицу с данными технологического журнала как показано на скриншотах.
Естественно что к результатам можно применять любой функционал T-SQL, например WHERE, ORDER BY или JOIN, например:
select distinct SqlText,CONTEXT from ParseLogFiles({сетевой каталог с файлами ТЖ})
where BaseName= 'YourBaseName' and CONTEXT is not null
Таким образом поиск контекста исполнения любого запроса, попавшего в журнал становится делом нескольких секунд.
Кроме того, в статье подробно описано как сохранять результаты выполнения этой функции на периодической основе, чтобы в дальнейшем сделать консолидированный анализ за период. Например отобрав самые "проблемные" участки кода за неделю, как первые кандидаты на оптимизацию.
Полностью статья доступна в приложенном файле. В дополнительных файлах можно скачать текст функции или уже откомпилированную сборку этой функции.
P. S. Можно пойти еще дальше и соединить результаты, возвращаемые функцией, с результатами некоторых DMV и получить максимально полную информацию в одной таблице. Например, на скриншоте приведено суммарное время выполнения запросов в SQL с контекстом исполнения в 1С (описание того как получить такой результат уже к сожалению выходит за рамки данной статьи).