В своих тестах я заметил, что время синтаксического анализа значительно увеличивается, если строка запроса длинная и содержит несколько подстановочных знаков.
Мне интересно, есть ли какие-либо оптимизации для ускорения синтаксического анализа или есть ли рекомендуемый способ лучше понять такое поведение синтаксического анализа. Я использую lucene 5.
Вот минимальный пример:
Код: Выделить всё
static String luceneQuery =
"fieldname:*hellomatethen?=?@*nocheckyz*xosdAK*bangbeat*randanhan\\ 7*nope\\ therealherl\\ baddy*caddy\\ okadlo*xomsdo\\ vac\\ racd*udotanda\\ logorand\\ bokonoso\\ maraloko*donopoa\\ zxcvbnm\\ mnbvcxz\\ asdfg\\ lkjhgfdsaz*poiuyt\\ qwert*mnb\\ lpmkojn\\ mkonjib*poiupoi*hahaha*pouiopi?=?@gyb\\:\\\\bhuuhbv\\\\tyughkv\\\\tyuibijd\\\\tyuioprewqasdf\\\\tyuioper\\\\ashu\\:\\\\njibhuvg\\\\aplzkcvjasd\\\\iop123wqwe\\\\7890acasd\\\\kjhbn8345601ad\\\\98ujhbgta*";
Код: Выделить всё
static String luceneQuery =
"fieldname:*hellomatethen?=?@*nocheckyz*xosdAK*bangbeat*randanhan\\ 7*nope\\ therealherl\\ baddy*caddy\\ okadlo*xomsdo\\ vac\\ racd*udotanda\\ logorand\\ bokonoso\\ maraloko*donopoa\\ zxcvbnm\\ mnbvcxz\\ asdfg\\ lkjhgfdsaz*poiuyt\\ qwert*mnb\\ lpmkojn\\ mkonjib*poiupoi*hahaha*pouiopi?=?@gyb\\:\\\\bhuuhbv\\\\tyughkv\\\\tyuibijd\\\\tyuioprewqasdf\\\\tyuioper\\\\ashu\\:\\\\njibhuvg\\\\aplzkcvjasd\\\\iop123wqwe\\\\7890acasd\\\\kjhbn8345601ad\\\\98ujhbgta*";
public static void main(String[] args) throws Exception {
QueryParser queryParser = new QueryParser("fieldname", new StandardAnalyzer());
queryParser.setAllowLeadingWildcard(true);
Query parsed = queryParser.parse(luceneQuery);
}Подробнее здесь: https://stackoverflow.com/questions/798 ... -character
Мобильная версия