org.nlpcn.es4sql.query.join.ESHashJoinQueryAction Maven / Gradle / Ivy
package org.nlpcn.es4sql.query.join;
import org.elasticsearch.client.Client;
import org.nlpcn.es4sql.domain.Condition;
import org.nlpcn.es4sql.domain.Field;
import org.nlpcn.es4sql.domain.JoinSelect;
import org.nlpcn.es4sql.domain.Where;
import org.nlpcn.es4sql.domain.hints.Hint;
import org.nlpcn.es4sql.domain.hints.HintType;
import org.nlpcn.es4sql.exception.SqlParseException;
import java.util.AbstractMap;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
/**
* Created by Eliran on 22/8/2015.
*/
public class ESHashJoinQueryAction extends ESJoinQueryAction {
public ESHashJoinQueryAction(Client client,JoinSelect joinSelect) {
super(client, joinSelect);
}
@Override
protected void fillSpecificRequestBuilder(JoinRequestBuilder requestBuilder) throws SqlParseException {
String t1Alias = joinSelect.getFirstTable().getAlias();
String t2Alias = joinSelect.getSecondTable().getAlias();
List>> comparisonFields = getComparisonFields(t1Alias, t2Alias,joinSelect.getConnectedWhere());
((HashJoinElasticRequestBuilder) requestBuilder).setT1ToT2FieldsComparison(comparisonFields);
}
@Override
protected JoinRequestBuilder createSpecificBuilder() {
return new HashJoinElasticRequestBuilder();
}
@Override
protected void updateRequestWithHints(JoinRequestBuilder requestBuilder) {
super.updateRequestWithHints(requestBuilder);
for(Hint hint : joinSelect.getHints()){
if(hint.getType() == HintType.HASH_WITH_TERMS_FILTER) {
((HashJoinElasticRequestBuilder) requestBuilder).setUseTermFiltersOptimization(true);
}
}
}
private List> getComparisonFields(String t1Alias, String t2Alias, List connectedConditions) throws SqlParseException {
List> comparisonFields = new ArrayList<>();
for(Condition condition : connectedConditions){
if(condition.getOpear() != Condition.OPEAR.EQ){
throw new SqlParseException(String.format("HashJoin should only be with EQ conditions, got:%s on condition:%s", condition.getOpear().name(), condition.toString()));
}
String firstField = condition.getName();
String secondField = condition.getValue().toString();
Field t1Field,t2Field;
if(firstField.startsWith(t1Alias)){
t1Field = new Field(removeAlias(firstField,t1Alias),null);
t2Field = new Field(removeAlias(secondField,t2Alias),null);
}
else {
t1Field = new Field(removeAlias(secondField,t1Alias),null);
t2Field = new Field(removeAlias(firstField,t2Alias),null);
}
comparisonFields.add(new AbstractMap.SimpleEntry(t1Field, t2Field));
}
return comparisonFields;
}
private List>> getComparisonFields(String t1Alias, String t2Alias, Where connectedWhere) throws SqlParseException {
List>> comparisonFields = new ArrayList<>();
//where is AND with lots of conditions.
if(connectedWhere == null) return comparisonFields;
boolean allAnds = true;
for(Where innerWhere : connectedWhere.getWheres()){
if(innerWhere.getConn() == Where.CONN.OR) {
allAnds = false;
break;
}
}
if(allAnds)
{
List> innerComparisonFields = getComparisonFieldsFromWhere(t1Alias, t2Alias, connectedWhere);
comparisonFields.add(innerComparisonFields);
}
else {
for(Where innerWhere : connectedWhere.getWheres()){
comparisonFields.add(getComparisonFieldsFromWhere(t1Alias,t2Alias,innerWhere));
}
}
return comparisonFields;
}
private List> getComparisonFieldsFromWhere(String t1Alias, String t2Alias, Where where) throws SqlParseException {
List conditions = new ArrayList<>();
if(where instanceof Condition)
conditions.add((Condition) where);
else {
for (Where innerWhere : where.getWheres()) {
if (!(innerWhere instanceof Condition))
throw new SqlParseException("if connectedCondition is AND than all inner wheres should be Conditions ");
conditions.add((Condition) innerWhere);
}
}
return getComparisonFields(t1Alias, t2Alias, conditions);
}
private String removeAlias(String field, String alias) {
return field.replace(alias+".","");
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy