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

nl.topicus.jdbc.shaded.com.google.cloud.spanner.BatchClientImpl Maven / Gradle / Ivy

There is a newer version: 1.1.6
Show newest version
/*
 * Copyright 2017 Google LLC
 *
 * 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 nl.topicus.jdbc.shaded.com.google.cloud.spanner;

import static nl.topicus.jdbc.shaded.com.google.common.base.Preconditions.checkNotNull;

import nl.topicus.jdbc.shaded.com.google.cloud.spanner.Options.QueryOption;
import nl.topicus.jdbc.shaded.com.google.cloud.spanner.Options.ReadOption;
import nl.topicus.jdbc.shaded.com.google.cloud.spanner.SpannerImpl.MultiUseReadOnlyTransaction;
import nl.topicus.jdbc.shaded.com.google.cloud.spanner.SpannerImpl.SessionImpl;
import nl.topicus.jdbc.shaded.com.google.cloud.spanner.spi.v1.SpannerRpc;
import nl.topicus.jdbc.shaded.com.google.common.base.Preconditions;
import nl.topicus.jdbc.shaded.com.google.common.collect.ImmutableList;
import nl.topicus.jdbc.shaded.com.google.protobuf.Struct;
import nl.topicus.jdbc.shaded.com.google.spanner.v1.ExecuteSqlRequest.QueryMode;
import nl.topicus.jdbc.shaded.com.google.spanner.v1.PartitionQueryRequest;
import nl.topicus.jdbc.shaded.com.google.spanner.v1.PartitionReadRequest;
import nl.topicus.jdbc.shaded.com.google.spanner.v1.PartitionResponse;
import nl.topicus.jdbc.shaded.com.google.spanner.v1.TransactionSelector;

import java.util.List;
import java.util.Map;
import java.util.concurrent.Callable;

/** Default implementation for Batch Client interface. */
public class BatchClientImpl implements BatchClient {
  private final SpannerImpl spanner;
  private final DatabaseId db;

  BatchClientImpl(DatabaseId db, SpannerImpl spanner) {
    this.db = checkNotNull(db);
    this.spanner = checkNotNull(spanner);
  }

  @Override
  public BatchReadOnlyTransaction batchReadOnlyTransaction(TimestampBound bound) {
    SessionImpl session = (SessionImpl) spanner.createSession(db);
    return new BatchReadOnlyTransactionImpl(spanner, session, checkNotNull(bound));
  }

  @Override
  public BatchReadOnlyTransaction batchReadOnlyTransaction(BatchTransactionId batchTransactionId) {
    SessionImpl session =
        spanner.sessionWithId(checkNotNull(batchTransactionId).getSessionId());
    return new BatchReadOnlyTransactionImpl(spanner, session, batchTransactionId);
  }

  private static class BatchReadOnlyTransactionImpl extends MultiUseReadOnlyTransaction
      implements BatchReadOnlyTransaction {
    private final String sessionName;
    private final Map options;

    BatchReadOnlyTransactionImpl(SpannerImpl spanner, SessionImpl session, TimestampBound bound) {
      super(
          checkNotNull(session),
          checkNotNull(bound),
          checkNotNull(spanner).getOptions().getSpannerRpcV1(),
          spanner.getOptions().getPrefetchChunks());
      this.sessionName = session.getName();
      this.options = session.getOptions();
      initTransaction();
    }

    BatchReadOnlyTransactionImpl(
        SpannerImpl spanner, SessionImpl session, BatchTransactionId batchTransactionId) {
      super(
          checkNotNull(session),
          checkNotNull(batchTransactionId).getTransactionId(),
          batchTransactionId.getTimestamp(),
          checkNotNull(spanner).getOptions().getSpannerRpcV1(),
          spanner.getOptions().getPrefetchChunks());
      this.sessionName = session.getName();
      this.options = session.getOptions();
    }

    @Override
    public BatchTransactionId getBatchTransactionId() {
      return new BatchTransactionId(sessionName, getTransactionId(), getReadTimestamp());
    }

    @Override
    public List partitionRead(
        PartitionOptions partitionOptions,
        String table,
        KeySet keys,
        Iterable columns,
        ReadOption... options) throws SpannerException {
      return partitionReadUsingIndex(
          partitionOptions, table, null /*index*/, keys, columns, options);
    }

    @Override
    public List partitionReadUsingIndex(
        PartitionOptions partitionOptions,
        String table,
        String index,
        KeySet keys,
        Iterable columns,
        ReadOption... option) throws SpannerException {
      Options readOptions = Options.fromReadOptions(option);
      Preconditions.checkArgument(
          !readOptions.hasLimit(),
          "Limit option not supported by partitionRead|partitionReadUsingIndex");
      final PartitionReadRequest.Builder builder =
          PartitionReadRequest.newBuilder()
              .setSession(sessionName)
              .setTable(checkNotNull(table))
              .addAllColumns(columns);
      keys.appendToProto(builder.getKeySetBuilder());
      if (index != null) {
        builder.setIndex(index);
      }
      TransactionSelector selector = getTransactionSelector();
      if (selector != null) {
        builder.setTransaction(selector);
      }
      nl.topicus.jdbc.shaded.com.google.spanner.v1.PartitionOptions.Builder pbuilder =
          nl.topicus.jdbc.shaded.com.google.spanner.v1.PartitionOptions.newBuilder();
      if (partitionOptions != null) {
        partitionOptions.appendToProto(pbuilder);
      }
      builder.setPartitionOptions(pbuilder.build());

      final PartitionReadRequest request = builder.build();
      PartitionResponse response =
          SpannerImpl.runWithRetries(
              new Callable() {
                @Override
                public PartitionResponse call() throws Exception {
                  return rpc.partitionRead(request, options);
                }
              });
      ImmutableList.Builder partitions = ImmutableList.builder();
      for (nl.topicus.jdbc.shaded.com.google.spanner.v1.Partition p : response.getPartitionsList()) {
        Partition partition =
            Partition.createReadPartition(
                p.getPartitionToken(), partitionOptions, table, index, keys, columns, readOptions);
        partitions.add(partition);
      }
      return partitions.build();
    }

    @Override
    public List partitionQuery(
        PartitionOptions partitionOptions, Statement statement, QueryOption... option)
        throws SpannerException {
      Options queryOptions = Options.fromQueryOptions(option);
      final PartitionQueryRequest.Builder builder =
          PartitionQueryRequest.newBuilder()
              .setSession(sessionName)
              .setSql(statement.getSql());
      Map stmtParameters = statement.getParameters();
      if (!stmtParameters.isEmpty()) {
        Struct.Builder paramsBuilder = builder.getParamsBuilder();
        for (Map.Entry param : stmtParameters.entrySet()) {
          paramsBuilder.putFields(param.getKey(), param.getValue().toProto());
          builder.putParamTypes(param.getKey(), param.getValue().getType().toProto());
        }
      }
      TransactionSelector selector = getTransactionSelector();
      if (selector != null) {
        builder.setTransaction(selector);
      }
      nl.topicus.jdbc.shaded.com.google.spanner.v1.PartitionOptions.Builder pbuilder =
          nl.topicus.jdbc.shaded.com.google.spanner.v1.PartitionOptions.newBuilder();
      if (partitionOptions != null) {
        partitionOptions.appendToProto(pbuilder);
      }
      builder.setPartitionOptions(pbuilder.build());

      final PartitionQueryRequest request = builder.build();
      PartitionResponse response =
          SpannerImpl.runWithRetries(
              new Callable() {
                @Override
                public PartitionResponse call() throws Exception {
                  return rpc.partitionQuery(request, options);
                }
              });
      ImmutableList.Builder partitions = ImmutableList.builder();
      for (nl.topicus.jdbc.shaded.com.google.spanner.v1.Partition p : response.getPartitionsList()) {
        Partition partition =
            Partition.createQueryPartition(
                p.getPartitionToken(), partitionOptions, statement, queryOptions);
        partitions.add(partition);
      }
      return partitions.build();
    }

    @Override
    public ResultSet execute(Partition partition) throws SpannerException {
      if (partition.getStatement() != null) {
        return executeQueryInternalWithOptions(
            partition.getStatement(),
            QueryMode.NORMAL,
            partition.getQueryOptions(),
            partition.getPartitionToken());
      }
      return readInternalWithOptions(
          partition.getTable(),
          partition.getIndex(),
          partition.getKeys(),
          partition.getColumns(),
          partition.getReadOptions(),
          partition.getPartitionToken());
    }

    @Override
    public void close() {
      super.close();
      session.close();
    }
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy