Нюансы Getdocumentsbykey

  • Автор темы Eugenus
  • Дата начала
E

Eugenus

#1
Добрый день, товарищи лотусники и лотусисты..
Второй раз возникла такая проблема:
Есть агент, который периодически (раз в пять минут по 120 циклов за один запуск) колбасит представление XXX, отбирая из него n-е количество документов через NotesView.GetDocumentsByKey по первому отсортированному столбцу. Так вот, вдруг внезапно, без видимых причин, в отобранной коллекции оказывается 0 документов, при том, что на самом деле их там должно быть больше ста. То есть метод GetDocumentsByKey не возвращает ни одного документа. При пересоздании вида (и соответственно его индекса) все налаживается. Вот собственно вопрос - может ли как-то самопроизвольно сбиться или убиться индекс для какого-либо представления ? На сервере запущены две задачи Update, не думаю, что они могут конфликтовать или причина в этом, но на всяй случай уточню..
 

lmike

нет, пердело совершенство
Lotus team
27.08.2008
6 583
269
#2
может ли как-то самопроизвольно сбиться или убиться индекс
может, причины разные
замечал - если ключ юнид, такое происходит (например)
ставьте регулярной задачей апдейт вьюшки (индекса)
 

ToxaRat

Чёрный маг
Lotus team
06.11.2007
3 231
18
#3
сервер устал ^_^
используется однопроходный алгоритм, проверте возможно быстрее и проще будет всосать весь вид в самодельную структуру и там уже колбаситься
 
E

Eugenus

#4
Хм, ключ не унид, но учту. Спасибо. ToxaRat: Насчет самодельной структуры - можно попробовать, но проблема не носит регулярный характер и обычно все колбасится быстро, без натуги. Да и там переписывать придется половину движка.

Добавлено: Кстати, а как запустить дополнительную задачу на апдейт одного представления ? Можно например агент создать, который будет регулярно рефрешить его, а административнми средствами сделать это можно ?
 

lmike

нет, пердело совершенство
Lotus team
27.08.2008
6 583
269
#5
это и нужно сделать
административнми средствами
создать документ программс в АК (хэлп админа)
команда в консоли:load updall dbname -R -T viewname
в программс её разделить надо и убрать load
 

rinsk

Lotus team
12.11.2009
900
44
#6
Хм, ключ не унид, но учту. Спасибо. ToxaRat: Насчет самодельной структуры - можно попробовать, но проблема не носит регулярный характер и обычно все колбасится быстро, без натуги. Да и там переписывать придется половину движка.
Попробуйте юзать конструкцию вместе с view.refresh. Т.е.

collection=view.GetDocumentsByKey(..)
if collection.Count=0 then
call view.Refresh()
collection=view.GetDocumentsByKey(..)
end if
 
E

Eugenus

#7
Imake:Спасибо. А что значит разделить ? Убрал load и прописал в Command Line
rinsk: Рефреш не прокатывает. Я это представление и обновлял и пересохранял, все равно в коллекции пусто, помогает только пересоздание, видимо, индекс не просто "неполный", а вообще отсутствует...
 

rinsk

Lotus team
12.11.2009
900
44
#8
rinsk: Рефреш не прокатывает. Я это представление и обновлял и пересохранял, все равно в коллекции пусто, помогает только пересоздание, видимо, индекс не просто "неполный", а вообще отсутствует...
Надо провести полный ремонт базы - Fixup\Compac -c -D + все последние фиксы.
Такого рода глюки были при проблемах с диском\контроллером и с самим Домино, когда странным образом летели индексы на нагруженной системе. Щас 852FP1 - врод все стабильно...