Форум программистов, компьютерный форум, киберфорум
HCL Notes: Программирование
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск  
 
 
Рейтинг 4.96/319: Рейтинг темы: голосов - 319, средняя оценка - 4.96
0 / 0 / 0
Регистрация: 23.02.2013
Сообщений: 38

Запрос Для Ftsearch

27.02.2013, 01:56. Показов 65854. Ответов 87
Метки нет (Все метки)

Товарищи, возникла необходимость оптимизации работы агента, долго выполняется обновление,при анализе кода было выявлено что большая часть времени тратится на операции поиска
DocumentCollection dc = database.search( "Form =\"Person\" & met!=\"1\" & @IsUnavailable($Conflict) & TabNum= \"" + tabNum + "\"");
DocumentCollection dc = database.search( "(Form =\"Department\" | Form =\"Subdivision\") & @IsUnavailable($Conflict) & met!=\"1\"& ID= \"" + depID + "\"");
DocumentCollection dc = database.search ("(Form =\"Department\" | Form = \"Subdivision\" )& ID=\""+parentId+"\" & met!=\"1\"");

Если верить интернетам метод FTSearch работает быстрее, но вот любой из этих запросов уже не работает если его вставить в FTSearch:

DocumentCollection dc = database.FTSearch( "Form =\"Person\" & met!=\"1\" & @IsUnavailable($Conflict) & TabNum= \"" + tabNum + "\"");
DocumentCollection dc = database.FTSearch( "(Form =\"Department\" | Form =\"Subdivision\") & @IsUnavailable($Conflict) & met!=\"1\"& ID= \"" + depID + "\"");
DocumentCollection dc = database.FTSearch("(Form =\"Department\" | Form = \"Subdivision\" )& ID=\""+parentId+"\" & met!=\"1\"");

эти варианты выдают ошибку типа error message: NotesException: Notes error: Query is not understandable ((Form ="Department" Form ="Subdivision") & @IsUnavailable($Conflict) & met!="1"& ID= "1000

Подскажите как правильно написать эти запросы для метода FTSearch или может какие нибудь еще варианты есть поиска ?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
27.02.2013, 01:56
Ответы с готовыми решениями:

запрос для Ftsearch: подскажите как выкрутиться
Ищу документы в БД при помощи Set dc = db.FTSearch(FTQuery, 0, 64,16384), где FTQuery довольно таки большая строка в которой указываю поля...

& @isavailable($conflict) для Ftsearch
Доброго времени. Собственно, вопрос в сабже.

Ftsearch
Здравствуйте. Ломаю голову, наверное не хватает опыта и так есть некая бд в domino в бд порядка 500000 документов. У каждого...

87
0 / 0 / 0
Регистрация: 23.02.2013
Сообщений: 38
15.04.2013, 16:35
Цитата Сообщение от lmike
continue;
http://sernam.ru/book_java.php?id=25
и итерирование коллекции не происходит
к тому же - в java надо делать recycle неиспользуемым объектам нотуса (это для избежания мемориликов)
Вы имеете ввиду так как чуть выхе предлагали сделать ?:

<!--shcode--><pre><code class=java>private lotus.domino.Document findByDepID1(String depID) throws NotesException, IOException {

if(depID==null || depID.equals("")){
log("findByDepID1: depID is Nothyng or Empty");
return null;
}

if(view1==null){
log("findByDepID1: view1 is Nothyng");
return null;
}

log("findByDepID1: depID = " + depID);

DocumentCollection dc = view1.getAllDocumentsByKey(depID);

if(dc.getCount()==0) {
log("findByDepID1: Collection <dc> by key depID is empty !");
dc.recycle;
return null;
}
boolean isMoreThanOne = false;
lotus.domino.Document tmpdoc = null;
lotus.domino.Document doc = dc.getFirstDocument();

while (doc!=null) {
if (!doc.isDeleted()) {
if (tmpdoc==null){
tmpdoc = doc;
}else{
isMoreThanOne = false;
break;
}
}
doc = dc.getNextDocument(doc);
}

if (isMoreThanOne) {
if (tmpdoc!=null) tmpdoc.recycle;
if (doc!=null) doc.recycle;
if (dc!=null) dc.recycle;
log("findByDepID1: There are more than one departament in DB with id = " + depID);
throw new RuntimeException("Error. There are more than one departament in DB with id = " + depID);
}else{
if (tmpdoc==null){
if (doc!=null) doc.recycle;
if (dc!=null) dc.recycle;
log("findByDepID1: There is no available(not conflict) doc with id = " + depID);
return null;
}else{
if (dc!=null) dc.recycle;
return tmpdoc;
}
}
}[/CODE]
0
0 / 0 / 0
Регистрация: 09.12.2012
Сообщений: 101
16.04.2013, 13:14
Именно по этой причине я предложил этот вариант, теперь Вам необходимо переделать метод findByTabNum1 по аналогии с findByDepID
0
1 / 1 / 0
Регистрация: 07.12.2009
Сообщений: 1,197
26.04.2013, 14:15
ezhov

Пример рабочих классов-итераторов .

P.S. Если дискуссия по Java, то лучше бы её вести в профильном разделе.
0
0 / 0 / 0
Регистрация: 27.10.2011
Сообщений: 2,124
26.04.2013, 15:53
VladSh
не, тут вопрос был ухода от FTSearch на более быстрое решение.
0
0 / 0 / 0
Регистрация: 13.02.2010
Сообщений: 437
31.07.2017, 15:14
Есть два дока с полями поле1 = "123" и поле1 = "123-45"
Вопрос, как сделать запрос FTSearch, чтобы находить только документ с поле1 = "123" ?
formula = {Field поле1= "123"} находит оба документа.
ищу
FTSearch(formula,0)
0
0 / 0 / 0
Регистрация: 04.11.2007
Сообщений: 3,019
31.07.2017, 15:20
возможно стоит разобраться с доп. параметрами в методе .FTSearch?
0
0 / 0 / 0
Регистрация: 13.02.2010
Сообщений: 437
31.07.2017, 15:51
FTSearch(formula,0,FT_SCORES,FT_STEMS) не работает. Выдает последним в коллекции самое точное вхождение, а точнее, не заметил зависимости.
0
0 / 0 / 0
Регистрация: 26.05.2006
Сообщений: 1,313
09.09.2017, 12:40
Цитата Сообщение от seoman2
Есть два дока с полями поле1 = "123" и поле1 = "123-45"
Вопрос, как сделать запрос FTSearch, чтобы находить только документ с поле1 = "123" ?
formula = {Field поле1= "123"} находит оба документа.
ищу
FTSearch(formula,0)
formula = {Field поле1= """123"""} ?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
09.09.2017, 12:40

Ftsearch
Всем привет! Столкнулся вот с каким приколом. FTSearch по базе не находит всех документов. Строка поиска, например, такая: ...

Ftsearch
При использовании NotesDatabase.FTSearch появляется ошибка &quot;Invalid note ID&quot;. Слышал, что могут при каких-то условиях генериться доки с...

Ftsearch
Set dcCollection = db.FTSearch( &quot;FIELD имя_поля=5&quot; , 0, FT_SCORES ) имя_поля типа Number Подскажите, почему оно не находит...

Ftsearch и ковычки
Как сделать, чтобы при точном поиске с FTSearch db.FTSearch(formula$,0) находились документы, чтобы в формуле запроса учитывались...

Коллекция. Ftsearch
Всем доброго времени суток!! Ответ скорее всего на поверхности, но не могу понять в чём дело... в базе у меня есть доки, в этих...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
88
Ответ Создать тему
Новые блоги и статьи
Программа для com-порта
Uhbif79 05.06.2026
Всем привет, давно хотел изучить Qt, начинал, бросал, потом снова начинал. И сейчас вот смог написать свою первую программу. До этого имел опыт программирования микроконтроллеров, писал прошивки на. . .
Транскрипция 55-минутного видео через Whisper: WhisperDesktop облажался, спас Google Colab[
anaschu 01.06.2026
Понадобилось получить текст из свежезагруженного видео на YouTube. Казалось бы, задача на пять минут. Заняла полтора часа. Делюсь опытом — может кому пригодится последовательность решений. . . .
21 мат мед. Планы на развитие модели здравоСохранения
anaschu 01.06.2026
AnyLogic: план развития симуляционной модели рабочего коллектива — динамический абсентеизм, реальные данные, три сценария сравнения Продолжаю серию постов о дискретно-событийной модели рабочего. . .
20. Мат мед. Абсентеизм как отдельный тип простоя
anaschu 29.05.2026
Апдейт модели: исправленные баги, абсентеизм и новые механизмы Продолжаю развивать ранее описанную модель рабочего коллектива на AnyLogic. За последние несколько дней был проведён серьёзный. . .
19. здоровье, усталость и психотип работника влияют на производительность предприятия, и наоборот, производительность на здоровье, усталось и психотип
anaschu 28.05.2026
Дискретно-событийная модель рабочего коллектива на AnyLogic: здоровье, выгорание, психотипы и микростимуляция Привет, коллеги. Хочу поделиться итогами нескольких недель работы над симуляционной. . .
"Прокси" для последовательного порта
Eddy_Em 28.05.2026
Эту штуку написал я достаточно давно. Но сейчас вот понадобилось настроить датчик грозы, но при этом не отключать его от "метеодемона". Соответственно, надо запустить этот "прокси": метеодемон будет. . .
Рефакторинг программы уравнивания.
Massaraksh7 26.05.2026
Пример по предыдущей записи в блоге. Но, надо заметить, что, во-первых, там оптимизация не только математики, но и работы с базой данных, и с графами, а во-вторых, это ещё не всё.
Использование TThread в Lazarus для математических вычислений.
Massaraksh7 25.05.2026
Производя рефакторинг своих программ на предмет ускорения их работы, обратил внимание на такой аспект, как сокращение времени матвычислений. Дело в том, что приходится работать с большими матрицами. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru