當前位置: 首頁>>代碼示例>>Java>>正文


Java MultiFieldQueryParser類代碼示例

本文整理匯總了Java中org.apache.lucene.queryparser.classic.MultiFieldQueryParser的典型用法代碼示例。如果您正苦於以下問題:Java MultiFieldQueryParser類的具體用法?Java MultiFieldQueryParser怎麽用?Java MultiFieldQueryParser使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


MultiFieldQueryParser類屬於org.apache.lucene.queryparser.classic包,在下文中一共展示了MultiFieldQueryParser類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: search

import org.apache.lucene.queryparser.classic.MultiFieldQueryParser; //導入依賴的package包/類
/**
 * Searches the lucene store for a specific query
 *
 * @param <T>       What type of information are we searching
 * @param clazz     The class of the information we are searching
 * @param queryText The query text
 * @return list of entities
 * @throws ParseException the parse exception
 */
public final <T extends BaseEntity> List<Object[]> search(final Class<T> clazz, final String queryText) throws ParseException {
    final FullTextEntityManager fullTextEntityManager = Search.getFullTextEntityManager(entityManager);

    final SearchFactory searchFactory = fullTextEntityManager.getSearchFactory();

    final QueryParser parser = new MultiFieldQueryParser(getClassLuceneFields(clazz), searchFactory.getAnalyzer(clazz));

    final List<Query> parsedQueries = Arrays.stream(queryText.split("AND"))
            .map(e -> parseQuery(e, parser))
            .filter(Objects::nonNull)
            .collect(Collectors.toList());

    final BooleanQuery.Builder bq = new BooleanQuery.Builder();
    parsedQueries.forEach(e -> bq.add(e, BooleanClause.Occur.MUST));

    final FullTextQuery jpaQuery = fullTextEntityManager.createFullTextQuery(bq.build(), clazz);
    jpaQuery.setProjection(ProjectionConstants.SCORE, ProjectionConstants.EXPLANATION, ProjectionConstants.THIS);

    return (List<Object[]>) jpaQuery.getResultList();
}
 
開發者ID:mhaddon,項目名稱:Sound.je,代碼行數:30,代碼來源:EntitySearch.java

示例2: findPosts

import org.apache.lucene.queryparser.classic.MultiFieldQueryParser; //導入依賴的package包/類
private List<Post> findPosts() {
	try {
		FullTextSession fullTextSession = getFullTextSession((Session) entityManager.getDelegate());
		Builder builder = new Builder();
		String[] fields = new String[] { "message.text", "topic.subject" };
		MultiFieldQueryParser parser = new MultiFieldQueryParser(fields, new StandardAnalyzer());
		builder.add(parser.parse(POST_TEXT), MUST);
		builder.add(new TermQuery(new Term("topic.forum.id", "0")), MUST);
		builder.add(new TermQuery(new Term("topic.forum.category.id", "0")), MUST);
		builder.add(new WildcardQuery(new Term("poster.userId", "root")), MUST);
		addPostTimeQuery(builder);
		FullTextQuery fullTextQuery = fullTextSession.createFullTextQuery(builder.build(), Post.class);
		fullTextQuery.setSort(getSort());
		fullTextQuery.setFirstResult(0);
		fullTextQuery.setMaxResults(15);
		@SuppressWarnings("unchecked")
		List<Post> posts = fullTextQuery.list();
		return posts;
	} catch (ParseException e) {
		logger.severe("error");
		return null;
	}
}
 
開發者ID:PacktPublishing,項目名稱:Mastering-Java-EE-Development-with-WildFly,代碼行數:24,代碼來源:SearchTestCase.java

示例3: initialize

import org.apache.lucene.queryparser.classic.MultiFieldQueryParser; //導入依賴的package包/類
@Override
public void initialize(UimaContext context) throws ResourceInitializationException {
  super.initialize(context);
  hits = UimaContextHelper.getConfigParameterIntValue(context, "hits", 100);
  // query constructor
  constructor = UimaContextHelper.createObjectFromConfigParameter(context,
          "query-string-constructor", "query-string-constructor-params",
          BooleanBagOfPhraseQueryStringConstructor.class, QueryStringConstructor.class);
  // lucene
  Analyzer analyzer = UimaContextHelper.createObjectFromConfigParameter(context, "query-analyzer",
          "query-analyzer-params", StandardAnalyzer.class, Analyzer.class);
  String[] fields = UimaContextHelper.getConfigParameterStringArrayValue(context, "fields");
  parser = new MultiFieldQueryParser(fields, analyzer);
  String index = UimaContextHelper.getConfigParameterStringValue(context, "index");
  try {
    reader = DirectoryReader.open(FSDirectory.open(Paths.get(index)));
  } catch (IOException e) {
    throw new ResourceInitializationException(e);
  }
  searcher = new IndexSearcher(reader);
  idFieldName = UimaContextHelper.getConfigParameterStringValue(context, "id-field", null);
  titleFieldName = UimaContextHelper.getConfigParameterStringValue(context, "title-field", null);
  textFieldName = UimaContextHelper.getConfigParameterStringValue(context, "text-field", null);
  uriPrefix = UimaContextHelper.getConfigParameterStringValue(context, "uri-prefix", null);
}
 
開發者ID:oaqa,項目名稱:bioasq,代碼行數:26,代碼來源:LuceneDocumentRetrievalExecutor.java

示例4: search

import org.apache.lucene.queryparser.classic.MultiFieldQueryParser; //導入依賴的package包/類
public synchronized ObjectMatrix2D search(String searchString) {
	try {
		MultiFieldQueryParser p = new MultiFieldQueryParser(Version.LUCENE_47, new String[] { VALUESTRING },
				getAnalyzer());
		Query query = p.parse(searchString);
		TopDocs docs = getIndexSearcher().search(query, 100);
		ObjectMatrix2D result = ObjectMatrix2D.Factory.zeros(docs.totalHits, 3);
		for (int row = 0; row < docs.totalHits; row++) {
			ScoreDoc match = docs.scoreDocs[row];
			Document doc = getIndexSearcher().doc(match.doc);
			result.setAsFloat(match.score, row, 0);
			result.setAsObject(SerializationUtil.deserialize(doc.getBinaryValue(KEYDATA).bytes), row, 1);
			result.setAsObject(SerializationUtil.deserialize(doc.getBinaryValue(VALUEDATA).bytes), row, 2);
		}
		return result;
	} catch (Exception e) {
		throw new RuntimeException("could not search documents: " + searchString, e);
	}
}
 
開發者ID:ujmp,項目名稱:universal-java-matrix-package,代碼行數:20,代碼來源:LuceneMap.java

示例5: simConsqQuery

import org.apache.lucene.queryparser.classic.MultiFieldQueryParser; //導入依賴的package包/類
private Query simConsqQuery(String cons, String consVal, double sim) {
	String[] field = new String[] { cons };

	MultiFieldQueryParser parser = new MultiFieldQueryParser(
			org.apache.lucene.util.Version.LUCENE_48, field,
			new StandardAnalyzer(org.apache.lucene.util.Version.LUCENE_48));

	if (consVal == null || "".equals(consVal.trim())) {
		consVal = "\" \"";
	}

	Query q = null;
	try {
		q = parser.parse(QueryParser.escape(consVal + "~ "
				+ (int) ((1.0d - sim) * (consVal.length()))));
	} catch (ParseException e) {
		logger.log(ProdLevel.PROD, "EXCEPTION : " + e.getMessage());
	}

	// logger.log(ProdLevel.PROD, "Executing lucene query : " + q);
	return q;
}
 
開發者ID:dhruvgairola,項目名稱:privacyCleaning,代碼行數:23,代碼來源:ErrgenServiceImpl.java

示例6: buildApproxMatchingQuery

import org.apache.lucene.queryparser.classic.MultiFieldQueryParser; //導入依賴的package包/類
public Query buildApproxMatchingQuery(String colsStr, List<String> cols) {

		StringBuilder sb = new StringBuilder();
		sb.append(colsStr);
		sb.append("~");

		MultiFieldQueryParser parser = new MultiFieldQueryParser(
				org.apache.lucene.util.Version.LUCENE_48,
				cols.toArray(new String[cols.size()]), new StandardAnalyzer(
						org.apache.lucene.util.Version.LUCENE_48));

		Query q = null;
		try {
			q = parser.parse(QueryParser.escape(sb.toString()));

			// logger.log(DebugLevel.DEBUG, "Approx data matching query : " +
			// q);

		} catch (ParseException e) {
			logger.log(ProdLevel.PROD, "EXCEPTION : " + e.getMessage());
		}

		return q;

	}
 
開發者ID:dhruvgairola,項目名稱:privacyCleaning,代碼行數:26,代碼來源:MatchingServiceImpl.java

示例7: getQueryParser

import org.apache.lucene.queryparser.classic.MultiFieldQueryParser; //導入依賴的package包/類
private MultiFieldQueryParser getQueryParser() {
    MultiFieldQueryParser queryParser = new MultiFieldQueryParser(getAllDefaultSearchableFields(), analyzer) {
        @Override
        protected Query getRangeQuery(String field, String part1, String part2, boolean startInclusive,
                boolean endInclusive) throws ParseException {
            if (field != null && getIndex(field).numeric) {
                Long min = getWithDefault(part1, null);
                Long max = getWithDefault(part2, null);
                return NumericRangeQuery.newLongRange(field, min, max, true, true);
            } else if (field != null) {
                return new TermQuery(new Term(field));
            }
            return super.getRangeQuery(null, part1, part2, startInclusive, endInclusive);
        }
    };
    queryParser.setDefaultOperator(QueryParser.Operator.AND);
    queryParser.setLocale(LOCALE);
    queryParser.setAnalyzeRangeTerms(true);
    queryParser.setLowercaseExpandedTerms(true);
    return queryParser;
}
 
開發者ID:jenkinsci,項目名稱:lucene-search-plugin,代碼行數:22,代碼來源:LuceneSearchBackend.java

示例8: qs

import org.apache.lucene.queryparser.classic.MultiFieldQueryParser; //導入依賴的package包/類
/**
 * Tries to parse a query string in order to check if it is valid.
 * @param query a Lucene query string
 * @return the query if valid, or '*' if invalid
 */
static Query qs(String query, Collection<String> fields) {
	if (fields == null || fields.isEmpty()) {
		fields = Collections.singletonList(Config._NAME);
	}
	if (StringUtils.isBlank(query)) {
		query = "*";
	}
	MultiFieldQueryParser parser = new MultiFieldQueryParser(fields.toArray(new String[0]), new StandardAnalyzer());
	parser.setAllowLeadingWildcard(false);
	//parser.setLowercaseExpandedTerms(false); // DEPRECATED in Lucene 7.x
	query = query.trim();
	if (query.length() > 1 && query.startsWith("*")) {
		query = query.substring(1);
	}
	if (!StringUtils.isBlank(query) && !"*".equals(query)) {
		try {
			Query q = parser.parse(query);
			return q;
		} catch (Exception ex) {
			logger.warn("Failed to parse query string '{}'.", query);
		}
	}
	return new MatchAllDocsQuery();
}
 
開發者ID:Erudika,項目名稱:para,代碼行數:30,代碼來源:LuceneUtils.java

示例9: search

import org.apache.lucene.queryparser.classic.MultiFieldQueryParser; //導入依賴的package包/類
public Set<String> search(String q) throws IOException {
    Set<String> recipes = new LinkedHashSet<>();
    String fields[] = new String[]{"description", "steps"};
    logger.debug(String.format("searching for %s", q));

    try (IndexReader reader = DirectoryReader.open(index)) {
        int hitsPerPage = 1000;
        IndexSearcher searcher = new IndexSearcher(reader);
        Query query = new MultiFieldQueryParser(fields, analyzer).parse(q);
        TopScoreDocCollector collector = TopScoreDocCollector.create(hitsPerPage, null);
        searcher.search(query, collector);

        ScoreDoc[] hits = collector.topDocs().scoreDocs;
        for (ScoreDoc hit : hits) {
            Document d = searcher.doc(hit.doc);
            recipes.add(d.get("title"));
        }

    } catch (CorruptIndexException | ParseException e) {
        logger.error(e);
    }

    logger.debug(String.format("found %d results", recipes.size()));
    return recipes;
}
 
開發者ID:anycook,項目名稱:anycook-api,代碼行數:26,代碼來源:FulltextIndex.java

示例10: searchPage

import org.apache.lucene.queryparser.classic.MultiFieldQueryParser; //導入依賴的package包/類
@RequestMapping(value = "/search", method = RequestMethod.GET)
public String searchPage(
        Model model,
        @RequestParam(value = "keyword", required = false) String keyword) {

    String[] fieldList = {"uid", "rpcid", "traceid", "rt_type", "url", "param", "ip", "httpcod", "project"};

    Map<String, Float> boosts = new HashMap<>();
    boosts.put("uid", 1.0f);
    boosts.put("ip", 1.0f);
    boosts.put("rpcid", 1.0f);
    boosts.put("traceid", 1.0f);
    boosts.put("rt_type", 1.0f);
    boosts.put("url", 1.0f);
    boosts.put("urlraw", 1.0f);
    boosts.put("param", 1.0f);
    boosts.put("httpcode", 1.0f);
    boosts.put("project", 1.0f);

    MultiFieldQueryParser mulFieldQueryParser = new MultiFieldQueryParser(fieldList, new StandardAnalyzer(), boosts);
    Query query;
    try {
        query = mulFieldQueryParser.parse(keyword);
    } catch (Exception e) {
        model.addAttribute("msg", "query parser error");
        return "search";
    }

    Sort sort = new Sort(new SortField("time", SortField.Type.DOUBLE, true));

    ResponseJson result = indexHelper.searchByQuery(DateTimeHelper.getCurrentTime(), query, 0, 1000, sort);
    model.addAttribute("resultlist", result.getResult());
    model.addAttribute("keyword", keyword);
    return "search";
}
 
開發者ID:weiboad,項目名稱:fiery,代碼行數:36,代碼來源:SearchPage.java

示例11: string

import org.apache.lucene.queryparser.classic.MultiFieldQueryParser; //導入依賴的package包/類
protected void string(StringQuery<T> stringQuery) {
    try {
        String[] fields = stringQuery.getFields();
        IndexedTypeIdentifier iti = getIndexedTypeIdentifier(stringQuery.getEntityClass());
        Analyzer analyzer = getSearchIntegrator().getAnalyzer(iti);
        QueryParser parser = new MultiFieldQueryParser(fields, analyzer);
        Query luceneQuery = parser.parse(stringQuery.getQuery());
        fillQuery(stringQuery, luceneQuery);
    } catch (ParseException e) {
        throw new RuntimeException(e);
    }
}
 
開發者ID:snowdrop,項目名稱:spring-data-snowdrop,代碼行數:13,代碼來源:LuceneQueryAdapter.java

示例12: createLuceneQuery

import org.apache.lucene.queryparser.classic.MultiFieldQueryParser; //導入依賴的package包/類
private org.apache.lucene.search.Query createLuceneQuery(String query) {
    try {
        return MultiFieldQueryParser.parse(
                new String[] {query}, 
                new String[] {field}, 
                analyzer);
    } catch (ParseException e) {
        throw new QueryException("Cannot parse query", e);
    }
}
 
開發者ID:oehf,項目名稱:ipf-flow-manager,代碼行數:11,代碼來源:Query.java

示例13: runQuery

import org.apache.lucene.queryparser.classic.MultiFieldQueryParser; //導入依賴的package包/類
/**
 * Performs scoring on the query provided.
 * @param qno
 * @param queryTerms
 * @return
 */
public ScoreDoc[] runQuery(String qno, String queryTerms){
    ScoreDoc[] hits = null;
    String[] fields = new String[fl.fields.size()];
    Map<String, Float> boosts = new HashMap<>();
    int i = 0;
    for (Field f : fl.fields) {
        fields[i] = f.fieldName;
        boosts.put(f.fieldName, f.fieldBoost);
        i++;
    }
    try {
        MultiFieldQueryParser mfq = new MultiFieldQueryParser(fields, analyzer, boosts);
        Query q = mfq.parse(queryTerms);
        System.out.println(qno+ ": " + q.toString());
        try {
            TopDocs results = searcher.search(q, p.maxResults);
            hits = results.scoreDocs;
        } catch (IOException ioe) {
            System.out.println(" caught a " + ioe.getClass() +
                    "\n with message: " + ioe.getMessage());
        }
    } catch (ParseException pe){
        System.out.println("Can't parse query");
    }
    return hits;
}
 
開發者ID:lucene4ir,項目名稱:lucene4ir,代碼行數:33,代碼來源:FieldedRetrievalApp.java

示例14: getQueryParser

import org.apache.lucene.queryparser.classic.MultiFieldQueryParser; //導入依賴的package包/類
private MultiFieldQueryParser getQueryParser(final Analyzer analyzer) {
    final Map<String, Float> boosts = new HashMap<String, Float>();
    boosts.put("title", 2.5F);
    boosts.put("description", 2F);
    boosts.put("owner.name", 1.5F);
    boosts.put("owner.username", 1.3F);
    return new MultiFieldQueryParser(LuceneUtils.LUCENE_VERSION, FIELDS_FULL_TEXT, analyzer, boosts);
}
 
開發者ID:mateli,項目名稱:OpenCyclos,代碼行數:9,代碼來源:AdDAOImpl.java

示例15: getQueryParser

import org.apache.lucene.queryparser.classic.MultiFieldQueryParser; //導入依賴的package包/類
private MultiFieldQueryParser getQueryParser(final Analyzer analyzer) {
    final Map<String, Float> boosts = new HashMap<String, Float>();
    boosts.put("customValues", 2F);
    boosts.put("by.name", 0.5F);
    boosts.put("by.username", 0.5F);
    return new MultiFieldQueryParser(LuceneUtils.LUCENE_VERSION, FIELDS_FULL_TEXT, analyzer, boosts);
}
 
開發者ID:mateli,項目名稱:OpenCyclos,代碼行數:8,代碼來源:MemberRecordDAOImpl.java


注:本文中的org.apache.lucene.queryparser.classic.MultiFieldQueryParser類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。