blob: d28253ad4d33fe172903b0dc7abf242a2929e58e [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you 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 org.apache.wayang.jdbc.operators;
import org.apache.wayang.basic.data.Record;
import org.apache.wayang.basic.operators.FilterOperator;
import org.apache.wayang.core.api.Configuration;
import org.apache.wayang.core.function.PredicateDescriptor;
import org.apache.wayang.core.optimizer.costs.LoadProfileEstimator;
import org.apache.wayang.core.optimizer.costs.LoadProfileEstimators;
import org.apache.wayang.jdbc.compiler.FunctionCompiler;
import java.sql.Connection;
import java.util.Optional;
/**
* Template for JDBC-based {@link FilterOperator}.
*/
public abstract class JdbcFilterOperator extends FilterOperator<Record> implements JdbcExecutionOperator {
public JdbcFilterOperator(PredicateDescriptor<Record> predicateDescriptor) {
super(predicateDescriptor);
}
public JdbcFilterOperator(FilterOperator<Record> that) {
super(that);
}
@Override
public String createSqlClause(Connection connection, FunctionCompiler compiler) {
return compiler.compile(this.predicateDescriptor);
}
@Override
public String getLoadProfileEstimatorConfigurationKey() {
return String.format("wayang.%s.filter.load", this.getPlatform().getPlatformId());
}
@Override
public Optional<LoadProfileEstimator> createLoadProfileEstimator(Configuration configuration) {
final Optional<LoadProfileEstimator> optEstimator =
JdbcExecutionOperator.super.createLoadProfileEstimator(configuration);
LoadProfileEstimators.nestUdfEstimator(optEstimator, this.predicateDescriptor, configuration);
return optEstimator;
}
}