本文整理匯總了Java中org.apache.lucene.queryParser.QueryParser.setDefaultOperator方法的典型用法代碼示例。如果您正苦於以下問題:Java QueryParser.setDefaultOperator方法的具體用法?Java QueryParser.setDefaultOperator怎麽用?Java QueryParser.setDefaultOperator使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類org.apache.lucene.queryParser.QueryParser
的用法示例。
在下文中一共展示了QueryParser.setDefaultOperator方法的14個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: processArgument
import org.apache.lucene.queryParser.QueryParser; //導入方法依賴的package包/類
@Override
protected boolean processArgument(String arg) throws CLIOException {
try {
Analyzer analyzer = PubMedIndexUtils.getGlobalAnalyzer();
QueryParser parser = new QueryParser(PubMedIndexUtils.LUCENE_VERSION, PubMedIndexField.ABSTRACT.fieldName, analyzer);
parser.setDefaultOperator(QueryParser.AND_OPERATOR);
parser.setLowercaseExpandedTerms(false);
PubMedIndexUtils.log("parsing query: %s", arg);
Query q = parser.parse(arg);
PubMedIndexUtils.log("query: %s", q);
addClause(q);
return false;
}
catch (ParseException e) {
throw new CLIOException(e);
}
}
示例2: select
import org.apache.lucene.queryParser.QueryParser; //導入方法依賴的package包/類
/**
* Executes a select query.
* @param query The Lucene query
* @return An array of record IDs; an empty array if an error occured
* @throws IOException
*/
public int[] select(String query, String sortPrefix) throws ParseException{
try {
WhitespaceAnalyzer sa= new WhitespaceAnalyzer();
BooleanQuery.setMaxClauseCount(20000);//zbog heap-a
QueryParser p = new QueryParser("KW", sa);
p.setDefaultOperator(QueryParser.Operator.AND); //default operator je AND a ne OR kao sto je inace inicijalno
Query q = p.parse(query);
return select(q, sortPrefix);
} catch (Exception ex) {
if (ex instanceof ParseException )
throw (ParseException)ex;
log.warn(ex);
return new int[0];
}
}
示例3: getSubQueryFilters
import org.apache.lucene.queryParser.QueryParser; //導入方法依賴的package包/類
/**
* Execute the sub query facets and return the search results
* @throws ParseException
* @throws IOException
*/
private List<Filter> getSubQueryFilters( List<FacetFilter> filters,
IndexSearcher searcher) throws ParseException, IOException
{
List<Filter> luceneFilters = new LinkedList<Filter>();
for(FacetFilter filter : filters)
{
if(log.isDebugEnabled())
{
log.debug("adding filter for field " + filter.getField() + " and query " + filter.getQuery());
}
QueryParser subQueryParser = new QueryParser(Version.LUCENE_35, filter.getField(), analyzer);
subQueryParser.setDefaultOperator(QueryParser.AND_OPERATOR);
String fixedQuery = SearchHelper.prepareFacetSearchString(filter.getQuery(), false);
fixedQuery = "\"" + fixedQuery + "\"";
Query subQuery = subQueryParser.parse(fixedQuery);
if(log.isDebugEnabled())
{
log.debug("sub query ing getSubQueryFilters is " + fixedQuery);
}
luceneFilters.add(new QueryWrapperFilter(subQuery));
}
return luceneFilters;
}
示例4: query
import org.apache.lucene.queryParser.QueryParser; //導入方法依賴的package包/類
Query query( String keyOrNull, Object value, QueryContext contextOrNull )
{
if ( value instanceof Query )
{
return (Query) value;
}
QueryParser parser = new QueryParser( Version.LUCENE_30, keyOrNull, analyzer );
parser.setAllowLeadingWildcard( true );
parser.setLowercaseExpandedTerms( toLowerCase );
if ( contextOrNull != null && contextOrNull.getDefaultOperator() != null )
{
parser.setDefaultOperator( contextOrNull.getDefaultOperator() );
}
try
{
return parser.parse( value.toString() );
}
catch ( ParseException e )
{
throw new RuntimeException( e );
}
}
示例5: search
import org.apache.lucene.queryParser.QueryParser; //導入方法依賴的package包/類
@SuppressWarnings("unchecked")
@Transactional(readOnly = true)
public Page<Article> search(String keyword, Pageable pageable) {
if (StringUtils.isEmpty(keyword)) {
return new Page<Article>();
}
if (pageable == null) {
pageable = new Pageable();
}
try {
String text = QueryParser.escape(keyword);
QueryParser titleParser = new QueryParser(Version.LUCENE_35, "title", new IKAnalyzer());
titleParser.setDefaultOperator(QueryParser.AND_OPERATOR);
Query titleQuery = titleParser.parse(text);
FuzzyQuery titleFuzzyQuery = new FuzzyQuery(new Term("title", text), FUZZY_QUERY_MINIMUM_SIMILARITY);
Query contentQuery = new TermQuery(new Term("content", text));
Query isPublicationQuery = new TermQuery(new Term("isPublication", "true"));
BooleanQuery textQuery = new BooleanQuery();
BooleanQuery query = new BooleanQuery();
textQuery.add(titleQuery, Occur.SHOULD);
textQuery.add(titleFuzzyQuery, Occur.SHOULD);
textQuery.add(contentQuery, Occur.SHOULD);
query.add(isPublicationQuery, Occur.MUST);
query.add(textQuery, Occur.MUST);
FullTextEntityManager fullTextEntityManager = Search.getFullTextEntityManager(entityManager);
FullTextQuery fullTextQuery = fullTextEntityManager.createFullTextQuery(query, Article.class);
fullTextQuery.setSort(new Sort(new SortField[] { new SortField("isTop", SortField.STRING, true), new SortField(null, SortField.SCORE), new SortField("createDate", SortField.LONG, true) }));
fullTextQuery.setFirstResult((pageable.getPageNumber() - 1) * pageable.getPageSize());
fullTextQuery.setMaxResults(pageable.getPageSize());
return new Page<Article>(fullTextQuery.getResultList(), fullTextQuery.getResultSize(), pageable);
} catch (ParseException e) {
e.printStackTrace();
}
return new Page<Article>();
}
示例6: search
import org.apache.lucene.queryParser.QueryParser; //導入方法依賴的package包/類
/**
* 檢索
*
* @param keyword
*/
public static void search(String keyword) throws Exception {
IndexSearcher searcher = null;
try {
// 創建search
searcher = getIndexSearcher();
String[] fields = { "name", "author", "content" };
QueryParser queryParser = new MultiFieldQueryParser(Version.LUCENE_35, fields,
new StandardAnalyzer(Version.LUCENE_35));
queryParser.setDefaultOperator(QueryParser.AND_OPERATOR);
Query query = queryParser.parse(keyword);
// 查詢
TopDocs topDocs = searcher.search(query, MAX);
ScoreDoc[] scoreDocs = topDocs.scoreDocs;
logger.info("查詢到條數=" + scoreDocs.length);
for (ScoreDoc scoreDoc : scoreDocs) {
Document doc = searcher.doc(scoreDoc.doc);
logger.info("doc信息:" + "docId=" + scoreDoc.doc + "id=" + doc.get("id") + "author="
+ doc.get("author") + "name=" + doc.get("name") + "content="
+ doc.get("content"));
}
} catch (Exception e) {
logger.error("查詢失敗:" + e.getMessage());
throw e;
}
}
示例7: multiFieldQuery
import org.apache.lucene.queryParser.QueryParser; //導入方法依賴的package包/類
/**
* 多條搜索
* @param fields
* @param value
* @throws Exception
*/
public static void multiFieldQuery( String[] fields, String value,List<Document>docs) throws Exception {
try {
// 創建search
IndexSearcher searcher = getIndexSearcher();
QueryParser queryParser = new MultiFieldQueryParser(Version.LUCENE_35, fields,
new StandardAnalyzer(Version.LUCENE_35));
queryParser.setDefaultOperator(QueryParser.AND_OPERATOR);
Query query = queryParser.parse(value);
// 查詢
TopDocs topDocs = searcher.search(query, 1000);
ScoreDoc[] scoreDocs = topDocs.scoreDocs;
logger.info("查詢到條數=" + scoreDocs.length);
for (ScoreDoc scoreDoc : scoreDocs) {
Document doc = searcher.doc(scoreDoc.doc);
// logger.info("doc信息:" + " docId=" + scoreDoc.doc + " id=" + doc.get("id") + " author="
// + doc.get("author") + " name=" + doc.get("name") + " content="
// + doc.get("content"));
docs.add(doc);
}
} catch (Exception e) {
logger.error("termQuery查詢失敗");
throw e;
}
}
示例8: getQueryParser
import org.apache.lucene.queryParser.QueryParser; //導入方法依賴的package包/類
private final QueryParser getQueryParser( QueryDef qd ){
QueryParser toReturn;
if ( qd.boosts == null || qd.boosts.isEmpty( ) )
toReturn = new SpecialMultiFieldQueryParser( LUCENEVERSION, qd.fields, analyzer );
else
toReturn = new SpecialMultiFieldQueryParser( LUCENEVERSION, qd.fields, analyzer, qd.boosts );
toReturn.setDefaultOperator( defaultOperator );
return toReturn;
}
示例9: processFacetCategory
import org.apache.lucene.queryParser.QueryParser; //導入方法依賴的package包/類
/**
* Determines the number of hits for each facet across the main query.
*
* @param facets
* @param reader
* @param mainQueryBits
* @throws ParseException
* @throws IOException
*/
private void processFacetCategory(Collection<FacetResult> facets,
IndexReader reader,
DocIdSet mainQueryBits)
throws ParseException, IOException
{
for(FacetResult f : facets )
{
QueryParser subQueryParser = new QueryParser(Version.LUCENE_35, f.getField(), analyzer);
subQueryParser.setDefaultOperator(QueryParser.AND_OPERATOR);
String fixedQuery = SearchHelper.prepareFacetSearchString(f.getFacetName(), false);
fixedQuery = "\"" + fixedQuery + "\"";
Query subQuery = subQueryParser.parse(fixedQuery);
if(log.isDebugEnabled())
{
log.debug("Fiexed query in process Facet Category = " + fixedQuery);
}
QueryWrapperFilter subQueryWrapper = new QueryWrapperFilter(subQuery);
DocIdSet subQueryBits = subQueryWrapper.getDocIdSet(reader);
OpenBitSetDISI mainQuerybitSet = new OpenBitSetDISI(mainQueryBits.iterator(), maxNumberOfMainQueryHits);
OpenBitSetDISI subQuerybitSet = new OpenBitSetDISI(subQueryBits.iterator(), maxNumberOfMainQueryHits);
long count = getFacetHitCount(mainQuerybitSet, subQuerybitSet);
f.setHits(count);
}
}
示例10: selectAll1
import org.apache.lucene.queryParser.QueryParser; //導入方法依賴的package包/類
public Result selectAll1(String query, String sortPrefix)throws ParseException{
try {
WhitespaceAnalyzer sa= new WhitespaceAnalyzer();
Searcher searcher = new IndexSearcher(indexPath);
BooleanQuery.setMaxClauseCount(20000);//zbog heap-a
QueryParser p = new QueryParser("KW", sa);
p.setDefaultOperator(QueryParser.Operator.AND); //default operator je AND a ne OR kao sto je inace inicijalno
Query q = p.parse(query);
Hits hits;
if (sortPrefix == null || "".equals(sortPrefix))
hits = searcher.search(q);
else {
int sortType = SortField.STRING;
if ("RN_sort".equals(sortPrefix))
sortType = SortField.INT;
hits = searcher.search(q, new Sort(
new SortField(sortPrefix, sortType)));
}
int n = hits.length();
int[] retVal = new int[n];
List<String> invs = new ArrayList<String>();
Field[] tmp = null;
for (int i = 0; i < n; i++) {
String recordID = hits.doc(i).get("ID");
retVal[i] = Integer.parseInt(recordID);
tmp = hits.doc(i).getFields("IN");
if (tmp != null){
for (int j = 0; j<tmp.length; j++){
invs.add(tmp[j].stringValue());
}
}
}
searcher.close();
Result result = new Result();
result.setRecords(retVal);
result.setInvs(invs);
return result;
} catch (Exception ex) {
if (ex instanceof ParseException )
throw (ParseException)ex;
log.fatal(ex);
return null;
}
}
示例11: executeSearchWithFacets
import org.apache.lucene.queryParser.QueryParser; //導入方法依賴的package包/類
/**
* Get the facets and results
* @see edu.ur.ir.institution.InstitutionalItemSearchService#executeSearchWithFacets(java.lang.String, java.lang.String, int, int, int, int)
*/
public FacetSearchHelper executeSearchWithFacets(
String mainQueryString,
String indexFolder,
int numberOfHitsToProcessForFacets,
int numberOfResultsToCollectForFacets,
int numberOfFactsToShow,
int numberOfIdsToCollect,
int idsToCollectStartPosition )
throws CorruptIndexException, IOException, ParseException
{
log.debug("orginal query 4 = " + mainQueryString);
if( searchDirectoryIsEmpty(indexFolder) || isInvalidQuery(mainQueryString))
{
return new FacetSearchHelper(new HashSet<Long>(), 0, new HashMap<String, Collection<FacetResult>>(), mainQueryString);
}
FSDirectory directory = FSDirectory.open(new File(indexFolder));
IndexReader reader = IndexReader.open(directory, true);
IndexSearcher searcher = new IndexSearcher(reader);
QueryParser parser = new MultiFieldQueryParser(Version.LUCENE_35, fields, analyzer, getBoostedFields());
parser.setDefaultOperator(QueryParser.AND_OPERATOR);
// execute the main query - we will use this to extract data to determine the facet searches
// the search helper MUST BE SET TO FALSE if diacritic based searches are to work
// putting a * following a diacritic does not work
String executedQuery = SearchHelper.prepareMainSearchString(mainQueryString, false);
Query mainQuery = parser.parse(executedQuery);
if( log.isDebugEnabled() )
{
log.debug("main query = " + executedQuery );
log.debug("main query parsed = " + mainQuery + " maxNumberOfMainQueryHits = " + maxNumberOfMainQueryHits );
}
TopDocs topDocs = searcher.search(mainQuery, maxNumberOfMainQueryHits);
// determine the set of data we should use to determine facets
HashMap<String, HashMap<String, FacetResult>> possibleFacets = this.generateFacetSearches(
topDocs,
numberOfHitsToProcessForFacets,
numberOfResultsToCollectForFacets,
searcher);
QueryWrapperFilter mainQueryWrapper = new QueryWrapperFilter(mainQuery);
log.debug("executeSearchWithFacets 1 query = " + mainQuery);
DocIdSet mainQueryBits = mainQueryWrapper.getDocIdSet(reader);
OpenBitSetDISI mainQueryBitSet = new OpenBitSetDISI(mainQueryBits.iterator(), reader.maxDoc());
HashMap<String, Collection<FacetResult>> facetResults = new HashMap<String, Collection<FacetResult>>();
// process the data and determine the facets
FacetSearchHelper helper = processPossibleFacets(possibleFacets,
reader,
mainQueryBitSet,
facetResults,
topDocs,
numberOfIdsToCollect,
idsToCollectStartPosition,
numberOfFactsToShow,
mainQueryString,
searcher);
helper.setExecutedQuery(executedQuery);
searcher.close();
reader.close();
return helper;
}
示例12: executeSearchWithFacets
import org.apache.lucene.queryParser.QueryParser; //導入方法依賴的package包/類
/**
* Get the facets and results
* @see edu.ur.ir.researcher.ResearcherSearchService#executeSearchWithFacets(java.lang.String, java.lang.String, int, int, int, int)
*/
public FacetSearchHelper executeSearchWithFacets(
String mainQueryString,
String indexFolder,
int numberOfHitsToProcessForFacets,
int numberOfResultsToCollectForFacets,
int numberOfFactsToShow,
int numberOfIdsToCollect,
int idsToCollectStartPosition )
throws CorruptIndexException, IOException, ParseException
{
if( searchDirectoryIsEmpty(indexFolder) || isInvalidQuery(mainQueryString))
{
return new FacetSearchHelper(new HashSet<Long>(), 0, new HashMap<String, Collection<FacetResult>>(), mainQueryString);
}
FSDirectory directory = FSDirectory.open(new File(indexFolder));
IndexReader reader = IndexReader.open(directory);
IndexSearcher searcher = new IndexSearcher(reader);
QueryParser parser = new MultiFieldQueryParser(Version.LUCENE_35, fields, analyzer);
parser.setDefaultOperator(QueryParser.AND_OPERATOR);
HashMap<String, Collection<FacetResult>> facetResults = new HashMap<String, Collection<FacetResult>>();
// execute the main query - we will use this to extract data to determine the facet searches
String executedQuery = SearchHelper.prepareMainSearchString(mainQueryString, true);
Query mainQuery = parser.parse(executedQuery);
if( log.isDebugEnabled() )
{
log.debug("main query = " + executedQuery );
}
TopDocs hits = searcher.search(mainQuery, maxNumberOfMainQueryHits);
// determine the set of data we should use to determine facets
HashMap<String, HashMap<String, FacetResult>> possibleFacets = this.generateFacetSearches(hits,
numberOfHitsToProcessForFacets,
numberOfResultsToCollectForFacets,
searcher);
QueryWrapperFilter mainQueryWrapper = new QueryWrapperFilter(mainQuery);
log.debug("executeSearchWithFacets 1 query = " + mainQuery);
// get the bitset for main query
DocIdSet mainQueryBits = mainQueryWrapper.getDocIdSet(reader);
// process the data and determine the facets
FacetSearchHelper helper = this.processPossibleFacets(possibleFacets,
reader,
mainQueryBits,
facetResults,
hits,
numberOfIdsToCollect,
idsToCollectStartPosition,
numberOfFactsToShow,
mainQueryString,
searcher);
helper.setExecutedQuery(executedQuery);
searcher.close();
reader.close();
return helper;
}
示例13: getQuery
import org.apache.lucene.queryParser.QueryParser; //導入方法依賴的package包/類
private Query getQuery(final String field, final String query) throws ParseException {
final QueryParser queryParser = new QueryParser(LUCENE_VERSION, field, analyzer);
queryParser.setAllowLeadingWildcard(true);
queryParser.setDefaultOperator(QueryParser.Operator.AND);
return queryParser.parse(query);
}
示例14: parse
import org.apache.lucene.queryParser.QueryParser; //導入方法依賴的package包/類
public static Query parse(String field, String value, Operator op){
QueryParser parser = new QueryParser(BuguIndex.getInstance().getVersion(), field, BuguIndex.getInstance().getAnalyzer());
parser.setDefaultOperator(op);
return parse(parser, value);
}