com.facebook.presto.jdbc.internal.spi.TableHandle Maven / Gradle / Ivy
/*
* 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.facebook.presto.jdbc.internal.spi;
import com.facebook.presto.jdbc.internal.common.predicate.TupleDomain;
import com.facebook.presto.jdbc.internal.spi.connector.ConnectorTransactionHandle;
import com.facebook.presto.jdbc.internal.jackson.annotation.JsonCreator;
import com.facebook.presto.jdbc.internal.jackson.annotation.JsonProperty;
import java.util.Objects;
import java.util.Optional;
import java.util.function.Supplier;
import static java.util.Objects.requireNonNull;
public final class TableHandle
{
private final ConnectorId connectorId;
private final ConnectorTableHandle connectorHandle;
private final ConnectorTransactionHandle transaction;
// ConnectorTableHandle will represent the engine's view of data set on a table, we will deprecate ConnectorTableLayoutHandle later.
// TODO remove table layout once it is fully deprecated.
private final Optional layout;
// This is not serializable; for local execution only
private final Optional>> dynamicFilter;
@JsonCreator
public TableHandle(
@JsonProperty("connectorId") ConnectorId connectorId,
@JsonProperty("connectorHandle") ConnectorTableHandle connectorHandle,
@JsonProperty("transaction") ConnectorTransactionHandle transaction,
@JsonProperty("connectorTableLayout") Optional layout)
{
this(connectorId, connectorHandle, transaction, layout, Optional.empty());
}
public TableHandle(
ConnectorId connectorId,
ConnectorTableHandle connectorHandle,
ConnectorTransactionHandle transaction,
Optional layout,
Optional>> dynamicFilter)
{
this.connectorId = requireNonNull(connectorId, "connectorId is null");
this.connectorHandle = requireNonNull(connectorHandle, "connectorHandle is null");
this.transaction = requireNonNull(transaction, "transaction is null");
this.layout = requireNonNull(layout, "layout is null");
this.dynamicFilter = requireNonNull(dynamicFilter, "dynamicFilter is null");
}
@JsonProperty
public ConnectorId getConnectorId()
{
return connectorId;
}
@JsonProperty
public ConnectorTableHandle getConnectorHandle()
{
return connectorHandle;
}
@JsonProperty
public ConnectorTransactionHandle getTransaction()
{
return transaction;
}
@JsonProperty
public Optional getLayout()
{
return layout;
}
public Optional>> getDynamicFilter()
{
return dynamicFilter;
}
public TableHandle withDynamicFilter(Supplier> dynamicFilter)
{
requireNonNull(dynamicFilter, "dynamicFilter is null");
if (this.dynamicFilter.isPresent()) {
throw new RuntimeException("dynamicFilter already exists");
}
return new TableHandle(connectorId, connectorHandle, transaction, layout, Optional.of(dynamicFilter));
}
@Override
public boolean equals(Object obj)
{
if (this == obj) {
return true;
}
if (!(obj instanceof TableHandle)) {
return false;
}
TableHandle other = (TableHandle) obj;
// TODO: This is a big hack.
// Since equals method is not implemented for ConnectorTableLayoutHandle in some connectors, comparing layout might cause iterative optimizer fail to converge.
// Instead, for now we compare the existence of layout in table handles.
// This works for now since the engine only pushdown filter to connector once during optimization.
return Objects.equals(connectorId, other.connectorId) &&
Objects.equals(connectorHandle, other.connectorHandle) &&
Objects.equals(transaction, other.transaction) &&
Objects.equals(layout.isPresent(), other.layout.isPresent());
}
@Override
public int hashCode()
{
return Objects.hash(connectorId, connectorHandle, transaction, layout.isPresent());
}
@Override
public String toString()
{
StringBuilder stringBuilder = new StringBuilder(this.getClass().getSimpleName());
stringBuilder.append(" {");
stringBuilder.append("connectorId='").append(connectorId).append('\'');
stringBuilder.append(", connectorHandle='").append(connectorHandle).append('\'');
stringBuilder.append(", layout='").append(layout).append('\'');
stringBuilder.append('}');
return stringBuilder.toString();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy