All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.elefana.search.query.MatchQuery Maven / Gradle / Ivy

The newest version!
/*******************************************************************************
 * Copyright 2018 Viridian Software Limited
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *   http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 ******************************************************************************/
package com.elefana.search.query;

import com.elefana.api.indices.IndexTemplate;
import com.jsoniter.ValueType;
import com.jsoniter.any.Any;

public class MatchQuery extends Query {
	private static final String KEY_QUERY = "query";
	private static final String KEY_OPERATOR = "operator";
	private static final String KEY_TYPE = "type";
	private static final String KEY_ZERO_TERMS_QUERY = "zero_terms_query";
	private static final String KEY_BOOST = "boost";
	
	protected String fieldName;
	protected String query;
	protected String operator = "OR";
	protected String zeroTermsQuery = "NONE";
	protected double boost = 1.0;
	protected MatchMode matchMode = MatchMode.DEFAULT;
	
	public MatchQuery(Any queryContext) {
		super();
		
		for(Object fieldKey : queryContext.keys()) {
			final String fieldName = fieldKey.toString();
			this.fieldName = fieldName;
			
			Any fieldContext = queryContext.get(fieldName);
			if(fieldContext.valueType().equals(ValueType.OBJECT)) {
				query = fieldContext.get(KEY_QUERY).toString();
				if(fieldContext.get(KEY_OPERATOR).valueType().equals(ValueType.STRING)) {
					operator = fieldContext.get(KEY_OPERATOR).toString();
				}
				if(fieldContext.get(KEY_ZERO_TERMS_QUERY).valueType().equals(ValueType.STRING)) {
					zeroTermsQuery = fieldContext.get(KEY_ZERO_TERMS_QUERY).toString();
				}
				if(fieldContext.get(KEY_BOOST).valueType().equals(ValueType.NUMBER)) {
					boost = fieldContext.get(KEY_BOOST).toDouble();
				}
				if(fieldContext.get(KEY_TYPE).valueType().equals(ValueType.STRING)) {
					matchMode = MatchMode.valueOf(fieldContext.get(KEY_TYPE).toString().toUpperCase());
				}
			} else {
				query = fieldContext.toString();
			}
			break;
		}
	}
	
	@Override
	public String toSqlWhereClause(IndexTemplate indexTemplate) {
		switch(matchMode) {
		case PHRASE:
			return toPhraseSqlWhereClause();
		case PHRASE_PREFIX:
			return toPhrasePrefixSqlWhereClause();
		case DEFAULT:
		default:
			return toDefaultSqlWhereClause();
		}
	}
	
	protected String toPhrasePrefixSqlWhereClause() {
		return "_source->>'" + fieldName + "' ILIKE '" + query + "%'";
	}
	
	protected String toPhraseSqlWhereClause() {
		return "_source->>'" + fieldName + "' ILIKE '%" + query + "%'";
	}
		
	protected String toDefaultSqlWhereClause() {
		StringBuilder stringBuilder = new StringBuilder();
		String [] terms = query.split(" ");
		
		stringBuilder.append('(');
		for(int i = 0; i < terms.length; i++) {
			if(i > 0) {
				stringBuilder.append(" " + operator + " ");
			}
			stringBuilder.append("_source->>'" + fieldName + "' ILIKE '%" + terms[i] + "%'");
		}
		stringBuilder.append(')');
		return stringBuilder.toString();
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy