Во вложении к публикации - приложение для анализа файлов журнале регистрации (1Cv8.lgd). Протестировано на релизе платформы 8.3.13.1926.
Когда возникает спорный момент (провели документ закрытого периода, изменили реквизиты справочника) возникает необходимость посмотреть в журнале регистрации кто же такой "умный" )))
Но выборка записей из журнала регистрации зачастую превращается в длительную блокировку работы пользователей. Многим знакомая ситуация... Особенно если выборка из ТОЛСТОГО журнала за БОЛЬШОЙ период...
Обычно формат журнала 1С - "*.LGD". Этот формат хранения использует базу данных SQLITE. Вот для такого журнала и попробовал найти решение.
Задумка была такая - открыть базу данных журнала, не блокируя запись в нее самой 1С, прочитать по фильтру записи, показать в понятном виде.
Скорости выборки это скорее всего не добавило, но зато пользователи могут продолжить работать в 1С пока администратор 1С ищет "злодея"!
Не стану разбирать детали, как это реализовано (в сети полно информации о структуре таблиц и полей журнала), отмечу главное - перед тем как выполнить запрос к базе данных на выборку событий, нужно перевести базу в режим WAL. Иначе будет как и с штатными механизмами - работа в 1С будет парализована.
PRAGMA journal_mode=WAL;
select rowID, severity ...
Где лежит файл журнала? На сервере 1С, конечно же.
Поэтому запускать приложение надо на сервере 1С. Сам файл ищем в каталоге установки 1С.
Например: "C:\Program Files\1cv8\srvinfo\reg_1541\2b6e1946-fe4d-471c-8f4b-67457986bf28\1Cv8Log"
"2b6e1946-fe4d-471c-8f4b-67457986bf28" - можно подсмотреть в файле 1CV8Clst.lst
{0,
{7d1cb5ef-ff9c-4ded-a371-d69e692b336c,"Локальний кластер",1541,"1c1",0,0,0,60,0,0,0,
{1,
{"1c1",1541}
},0,0,1},
{12,
{2b6e1946-fe4d-471c-8f4b-67457986bf28,"Base1","","MSSQLServer","mssql0.local","base1",...
{e13b3ea3-48ae-48d5-9c04-8321f57086d8,"Base2","","MSSQLServer","mssql0.local","base2",...
{0,00010101000000,00010101000000,"","",""},0,1,"",0,"","",417},...
По просьбам трудящихся добавил поиск конкретного объекта по его GUID. GUID объекта можно узнать с помощью "ИР портативные".
Пробуем? ;-)